鱼C论坛

 找回密码
 立即注册
查看: 2073|回复: 4

[庖丁解牛] 004 ※ 函数#老祖宗大显神威 |【附prototype.js源码包】

[复制链接]
发表于 2018-6-22 17:01:24 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
关于为什么要学习JavaScript设计模式,请看:传送门




Jun-22-2018 16-20-51.gif


上一讲最后小不二基于prototype重写了方法,但是发现调用很麻烦。

代码:
  1. var a = new checkObject();
  2. a.checkName();
  3. a.checkPassword();
  4. a.checkEmail();
复制代码


玄武问他有什么办法优化,看到小不二面露难色,玄武说道。

“当然是可以避免的阿,就要在你声明的每一个方法末尾处将当前对象返回。在JS中this指向的就是当前对象,对不对?”

“是的”

“既然指向当前对象,那么我就可以将它返回,只需在每个方法里添加一个return”

代码:
  1. var  checkObject = function(){
  2.         checkObject.prototype = {
  3.             checkName : function(){
  4.                 return this
  5.             },
  6.             checkPassword : function(){
  7.                 return this
  8.             },
  9.             checkEmail : function(){
  10.                 return this
  11.             }
  12.         }
  13.     }
复制代码


"这样的话,当我们使用时就可以这么写了"

代码:
  1. a.checkName().checkEmail().checkPassword();
复制代码


“嗯嗯,好厉害的写法”

看到小不二激动好学的神情,玄武觉得小不二未来一定是一名得力干将,决定多教他点东西。

“小不二你用过prototype.js插件吗?”
源码包: prototype.zip (42.64 KB, 下载次数: 5, 售价: 3 鱼币)

“嗯,听说过,具体还没使用过,但我看咱们之前的项目中有用到。”

“是的,这个框架很好用,它封装了很多JS原生对象的拓展,假如我们想给每一个函数都添加你写的检测密码方法,只需这么写”

代码:
  1. Function.prototype.checkPassword = function(){}
复制代码


“这样别人使用这个方法的时候就很方便了,如果你习惯函数形式,还可以这么写”

代码:
  1. var f = new Function();
  2.     f.checkPassword();
复制代码


“嗯,第二种写法好简洁啊,但是这样会污染Function吧?”

“没错,所以还可以抽象出一个统一添加方法的功能方法”

代码:
  1. Function.prototype.addMethod = function(passWord,fn){
  2.         this(passWord) = fn;
  3.     }
复制代码


“这样后续别人添加密码验证,就可以这么写”

代码:
  1. var methods = new Function();
  2.     methods.addMethod('checkPassword',function(){
  3.         
  4.     });
  5.    
  6.     methods.checkPassword();
复制代码


“哇塞,这个框架好厉害,不过看起来有一点非常规,当我想链式添加多个方法,是不是在addMethod中将this返回呢?”

就像这样:
  1. Function.prototype.addMethod = function(passWord,fn){
  2.         this(passWord) = fn;
  3.         return this;
  4.     }
复制代码


“当然,可以这么写啦,JS是一种极其灵活的语言,你以后在咱们团队还有很多要学的哦~”

“请老大,放心,我会努力学习的”

...

预知后事如何,请看下回分解





课后作业


1、一开始的对话中,玄武是如何实现链式调用的,请写出代码。

2、自行下载,prototype.js框架,尝试调用玩一玩。



答案:
游客,如果您要查看本帖隐藏内容请回复





如果有收获,别忘了评分


                               
登录/注册后可看大图


这位鱼油,如果喜欢JS-设计模式,请订阅 专辑☞传送门)(不喜欢更要订阅



                               
登录/注册后可看大图

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2020-6-21 08:26:18 | 显示全部楼层
1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-2-3 18:11:42 | 显示全部楼层
return this
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2022-10-21 19:43:15 | 显示全部楼层
1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-12-22 20:15:57 | 显示全部楼层
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-25 15:01

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表