JavaScript代理模式的实现方法是什么
Admin 2022-10-19 群英技术资讯 322 次浏览
代理模式属于设计模式中结构型的设计模式;
定义:
顾名思义就是为一个对象提供一个代用品或占位符,以便控制对它的访问!
白话解释:
很多明星都是有经纪人的,如果要联系明显进行商演或者开演唱会之类的商业活动通过是需要先跟经纪人取得联系的,跟经纪人谈好了合作事宜之后经纪人再转达给某明星,然后某明星才会去参加活动;同样租房也是一个同样的道理,我们不管是租房还是买房,第一反应肯定是找链家这类的平台,因为我们只需要跟链家进行沟通,而链家去跟房东沟通,省去了我们直接和房东沟通的步骤;因为链家就是一个代理模式,它代理了这个房东的房源;
举个例子:
你作为一个追星狂魔,是某明星的忠诚粉丝;刚好某明星近期要过生日了,你准备送上礼物代表你的心意,正常的流程:
var Fans = { flower(){ star.reception( "花" ); } } var star = { reception: function (gift){ console.log( "收到粉丝的:" +gift); } } Fans.flower(); //收到粉丝的:花 |
你选择了买花寄给她,希望她能感受到你的心意;但是往往理想很丰满,现实很骨感!别忘了还有经纪人,因为签收你的礼物的往往不是明星本人而是经纪人:
var Fans = { flower(){ Agent.reception( "花" ); } } var Agent = { reception: function (gift){ console.log( "粉丝送的:" +gift); //粉丝送的:花 star.reception( "花" ); } } var star = { reception: function (gift){ console.log( "收到粉丝的:" +gift); } } Fans.flower(); //收到粉丝的:花 |
这里的经纪人就是一个简单的代理了,粉丝需要先把礼物给经纪人,经纪人再转给明星本人;
明星满心欢喜的看到粉丝寄过来的包裹的时候,拆开一看,原来是花!明星很不屑,所以告诉经纪人,以后凡是给我寄花的,通通不要给我了,你自己看着处理:
var Fans = { flower(){ Agent.reception( "花" ); } } var Agent = { reception: function (gift){ console.log( "粉丝送的:" +gift); //粉丝送的:花 if (gift != "花" ){ star.reception( "花" ); } } } var star = { reception: function (gift){ console.log( "收到粉丝的:" +gift); } } Fans.flower(); |
上面的程序中明星根本就没有收到粉丝寄过来的花,因为在经纪人那里就已经拦截处理了;通过经纪人来过滤掉一部分礼物,这种模式叫做保护代理;
粉丝送花明星收不到,那粉丝就转换一下思路,送点钱自己去买想要的东西吧!于是找到经纪人,给了经纪人一百万现金,让经纪人转达给明星本人;
function Money(){ this .total = "一百万现金" return this .total; } var Fans = { flower(){ Agent.reception(); } } var Agent = { reception: function (){ // console.log("粉丝送的:"+gift); let money = new Money(); star.reception(money.total); } } var star = { reception: function (gift){ console.log( "收到粉丝的:" +gift); //收到粉丝的:一百万现金 } } Fans.flower(); |
明星收到了一百万就很开心;这一百万因为不是花,没有被经纪人拦截过滤;所以明星本人就直接收到了,这种模式我们称为虚拟代理模式;
没用代理的时候我们的代码是这样的:
// 创建一个本体对象 var myImage = ( function (){ // 创建标签 var imgNode = document.createElement( 'img' ); // 添加到页面 document.body.appendChild( imgNode ); return { // 设置图片的src setSrc: function ( src ){ // 更改src imgNode.src = src; } } })(); myImage.setSrc( 'http:// image.qq.com/music/photo/k/000GGDys0yA0Nk.jpg' ); |
虚拟代理
// 创建一个本体对象 var myImage = ( function (){ // 创建标签 var imgNode = document.createElement( 'img' ); // 添加到页面 document.body.appendChild( imgNode ); return { // 设置图片的src setSrc: function ( src ){ // 更改src imgNode.src = src; } } })(); // 创建代理对象 var proxyImage = ( function (){ // 创建一个新的img标签 var img = new Image; // img 加载完成事件 img.onload = function (){ // 调用 myImage 替换src方法 myImage.setSrc( this .src ); } return { // 代理设置地址 setSrc: function ( src ){ // 预加载 loading myImage.setSrc( 'file:// /C:/Users/svenzeng/Desktop/loading.gif' ); // 赋值正常图片地址 img.src = src; } } })(); proxyImage.setSrc( 'http:// image.qq.com/music/photo/k/000GGDys0yA0Nk.jpg' ); |
上面这段代码运用代理模式来实现图片预加载,可以看到通过代理模式巧妙地将创建图片与预加载逻辑分离,并且在未来如果不需要预加载,只要改成请求本体代替请求代理对象就行。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
JS中如何实现红绿灯效果?红绿灯是我们日常很常见的,红绿灯效果就是红灯、黄灯和绿灯循环改延时的效果,那么我们用JavaScript怎样做这样的效果呢?文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
查询方法:1、点击“开始”按钮,打开“开始”菜单;2、在搜索框中输入“cmd”,点击“cmd.exe”程序来打开cmd命令窗口;3、在打开的cmd命令行中,使用cd命令进入nodejs安装目录,执行“node -v”命令即可查看到版本信息。
小程序怎样实现分页查询列表的模板,及代码是什么?下文有实例供大家参考,对大家了解操作过程或相关知识有一定的帮助,而且实用性强,希望这篇文章能帮助大家,下面我们一起来了解看看吧。
滚轮放大缩小的功能还是比较常见的,本文给大家分享vue中实现div内滚轮放大缩小的功能的方法,实现效果有表格可以实现放大缩小及拖拽,如下,那么具体怎样实现呢?下面我们详细的了解看看。
这篇文章给大家分享的是JS实现获取文本框的内容的方法。小编觉得挺实用的,对新手学习JavaScript的使用有帮助,因此分享给大家做个参考,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008