位置: 编程技术 - 正文

学习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延时加载方式)

  • 怎么下载税控盘开票软件
  • 虚开增值税如何获利
  • 税收对国家的影响及地位
  • 个人接私活需要缴税吗
  • 电子发票字迹不清怎么办
  • 个人专项扣除需要扣税吗
  • 商品和服务税收分类编码
  • 非同一控制下企业合并对价小于可辨认
  • 汇算清缴业务招待费调整分录
  • 工会经费计提多了跨年
  • 公司宿舍房租
  • 企业支付劳务费到底需要发票吗
  • 收购发票税率是什么意思
  • 关于财产保险公司的论文
  • 一般纳税人有哪些费用
  • 公司支付广告服务费账务处理
  • 购买汽车可以开普通发票吗
  • 一台设备发票开来0.5台怎么做账?
  • 补提的增值税应该记在哪里
  • 不动产抵押登记费记什么科目
  • 小规模纳税人确认收入时要确认税吗
  • 无形资产的增值税怎么算
  • 企业工会经费计提比例
  • wordpress使用
  • memory tester
  • 绩效奖个人所得怎么算
  • 房产税的应纳税额计算方法
  • form action target
  • 前端密码加密
  • 七月份收入
  • echarts-gl
  • 使用vue开发app
  • 净收入是营业收入吗
  • 对附属单位补助的资金性质是财政预算资金
  • 公司注销税款太多
  • 小企业会计准则和一般企业会计准则的区别
  • 异地如何申报纳税
  • 汇兑损益应计入
  • 公司代缴社保如何查询
  • 主营业务成本包括工资吗
  • 社保缴纳的时候可以用吗
  • 2010年漏记的费用,11年该如何记账?
  • 发票遗失重开需要收费吗?
  • 哪些发票可以抵扣增值税专用发票
  • 开红字发票必须要收回原发票并作废吗?
  • 航天金税盘维护费发票在哪打印
  • 2020年工伤赔偿标准表
  • sqlserver 获取字符位置
  • sql 随机
  • sqlserver响应好慢
  • 侧边栏应用
  • 预览版与正式版
  • win10音量调节不显示
  • 怎么卸载xp系统
  • winxp/win2000/win2003
  • macbookair无响应
  • linux深入理解
  • mac 菜单
  • win7如何访问xp
  • win7音量图标不能启用
  • win7开机假死
  • linux怎么恢复到初始状态
  • win7怎么取消锁定
  • 电脑开机出现windows7
  • win8.1系统怎么激活
  • cocos2dx4.0教程
  • 如何使用蓝牙耳机
  • jquery日程安排
  • python的基本数值类型
  • 悬浮广告怎么屏蔽
  • python signal模块
  • python爬取某人所有朋友圈
  • androidsdk的计算机
  • 开票软件连接服务器失败什么原因
  • 已抵扣过进项税额的固定资产改变用途
  • 简述进料加工对中国的意义
  • 江苏电子税务局客服电话
  • 区地税局会不会分到乡镇
  • 长途汽车车次号
  • 公司业务专用章有法律作用吗
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设