位置: 编程技术 - 正文

学习JavaScript设计模式(链式调用)(javascript教程chm)

编辑:rootadmin

推荐整理分享学习JavaScript设计模式(链式调用)(javascript教程chm),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:javascript怎么学,javascript课设,javascript课设,javascript教程chm,javascript课设,javascript教程chm,javascript教程chm,javascript设计,内容如对您有帮助,希望把文章链接给更多的朋友!

1、什么是链式调用这个很容易理解,例如:

一般的函数调用和链式调用的区别:调用完方法后,return this返回当前调用方法的对象。

2、分解链式调用

链式调用其实是两个部分:

1).操作对象(也就是被操作的DOM元素,如上例的$(this))

2).操作方法(具体要做什么事情,如上例的setStyle和show)

如何实现操作对象与操作方法

创建一般的$函数:

但是,如果把这个函数改造为一个构造器,把那些元素作为数组保存在一个实例属性中,并让所有定义在构造器函数的prototype属性所指对象中的方法都返回用以调用方法的那个实例的引用,那么它就具有了链式调用的能力。(说了这么多,就是在每个方法最后return this;),

我首先需要把这个$函数改为一个工厂方法,它负责创建支持链式调用的对象。这个函数应该能接受元素数组形式的参数,以便我们能够使用与原来一样的公用接口。这样以来,它就具有了进行链式调用的能力。

学习JavaScript设计模式(链式调用)(javascript教程chm)

改造后如下:

在最后return this,这就将调用方法的对象传给调用链上的下一个方法。

3、模拟jquery底层链式编程

4、使用回调函数从支持链式调用的方法获取数据

链式调用很适合于赋值器方法,但对于取值器方法,就不方便了,因为每个方法返回的都是this啊。

不过,变通的方法还是有的,那就是回调函数。

未使用回调函数时

使用回调函数时

在使用回调函数时候callback.call(this, name)在一般情况下是没问题的,但是,这个例子偏偏用到了console.log,那么就有问题了。原因是console的this是指向console而不是winodw。

这个问题也很好解决。如下:

链式调用这种风格有助于简化代码的编写工作,让代码更加简洁、易读,同时也避免多次重复使用一个对象变量,希望大家可以熟练掌握。

js实现延时加载Flash的方法 本文实例讲述了js实现延时加载Flash的方法。分享给大家供大家参考,具体如下:当页面中包含自动播放视频的flash播放器时,flash的流媒体播放会一直不

Javascript BOM学习小结(六) 1、BOM简介。所谓的BOM即浏览器对象模型(BrowserObjectModel)。BOM赋予了JS操作浏览器的能力,即window操作。DOM则用于创建删除节点,操作HTML文档。BOM尚无

Javascript模仿淘宝信用评价实例(附源码) 本文实例讲述了Javascript模仿淘宝信用评价实现方法。分享给大家供大家参考,具体如下:老板昨天开会说:要给公司的购物平台增加信用评价功能,用户

标签: javascript教程chm

本文链接地址:https://www.jiuchutong.com/biancheng/386288.html 转载请保留说明!

上一篇:学习JavaScript设计模式(继承)(javascript怎么学)

下一篇:js实现延时加载Flash的方法(js延时加载方式)

  • 3901100090的暂定税率
  • 个人所得税纳税义务人
  • 支付外国公司费用要交税吗
  • 医院纯收入
  • 商贸企业购进商品怎么做成本
  • 其他应付款年终怎么结转
  • 防伪税控开具发票明细表
  • 非行政性罚款可以撤销吗
  • 筹资活动现金流量净额为负
  • 品种法怎么计算在产品成本
  • 研发废料收入抵研发
  • 道路占用挖掘费要交印花税吗
  • 缴纳税费及工会经费
  • 建筑业的发票
  • 现金流量计划中的税金怎么算
  • 分公司背书给总公司
  • 报关税怎么做账
  • 建筑业简易计税分包差额申报
  • 小规模纳税人代账流程
  • 转让股权收入属于企业所得税收入吗
  • 承兑汇票怎么换算
  • 待处理财产损益计入资产负债表哪里
  • 分公司的款汇入总公司得出什么证明
  • 银行承兑汇票保证金是什么意思
  • linux的rz
  • 工程筹建期间发票怎么开
  • 在win10中怎么从edge旧ie浏览器
  • php递归函数详解
  • php检测文件是否存在
  • php面向对象优点,缺点
  • php数组函数大全
  • 苹果语音备忘录怎么导出
  • ccmexec.exe是什么程序
  • php的教程
  • 公司报销客户的差旅费
  • PHP:finfo_set_flags()的用法_fileinfo函数
  • 莱姆 惨败
  • 货款退回账务处理方法
  • php处理并发有哪些技术
  • 现金溢余和短缺的会计分录
  • 流动资产的含义及常见项目
  • 外账是代理记账吗
  • dedecms配置
  • 控股子公司注销公告是利空吗
  • 个人独资企业是不是个体工商户
  • 出口合同的流程
  • 其他综合收益转入盈余公积和未分配利润
  • 政府会计制度应收账款坏账准备
  • 勾选认证能够勾选当月
  • 财务费用多计怎么做账
  • 2020年防洪基金计算公式
  • 年末结转本年利润分录
  • 清算资金往来借贷方什么意思
  • 客户退货不退赠品怎么办
  • 公司出资给另一个公司
  • 采购未取得发票怎么结转成本
  • 工会经费不够
  • 建设工程毛利率如何计算
  • doc怎么使用
  • ubuntu 16.04下mysql5.7.17开放远程3306端口
  • Linux安装MySQL教程(二进制分发版)
  • nvidia发布了G6X
  • won10怎么安装
  • windows2003远程桌面服务
  • macbookpro移到废纸篓快捷键
  • linux怎么分盘
  • linux中使用find命令查找文件
  • py常用函数
  • cocos jsc
  • jqgrid getrowdata
  • nodejs拼接路径的方法
  • python 递归函数与循环的区别
  • 使用jQuery Ajax 请求webservice来实现更简练的Ajax
  • 常用的javascript对象
  • 转让土地的土地增值税
  • 个人所得税税前扣除是什么意思
  • 国有企业全面改革方案
  • 消费税的征税范围包括
  • 开健身会所国家有补贴吗
  • 税务内控机制建设
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设