位置: 编程技术 - 正文

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

  • 企业中秋晚会活动方案
  • 主管税务机关是否参与清算
  • 企业信用公示的时效是多久
  • 一般纳税人跨月红冲专票怎么报税
  • 费用发票跨月可以入帐吗
  • 培训发生的差旅费怎么记账
  • 开具红字信息表后怎么开负数发票
  • 利润表年底净利润是正数吗
  • 固定资产抵债要交税吗怎么交
  • 捐赠利得会计分录
  • 进口设备贴息政策2019
  • 福利费进项税可以抵扣
  • 增值税发票抵扣进项税什么意思
  • 办公设备的税收编码
  • 旅游服务费可以抵扣增值税
  • 电子银行承兑汇票有风险吗
  • 小规模印花税减免性质代码和项目名称
  • 应付供货单位的货款属于什么会计科目
  • 会员卡充值赠送金额怎么做账
  • 向境外企业购买国内企业股权
  • 车间固定资产修理费
  • 培训的餐费入什么科目
  • 货车的折旧率
  • 投资收益填在经营所得申报表的哪里
  • 资产负债表待摊费用出现负数
  • 外资公司办事处职能
  • linux安装c语言环境
  • 如何手动更新目录
  • 物业公司收取水电周转金后果
  • 如何更改文件的创建时间
  • 纳税人如何申请延期缴纳税款
  • rk3328 sdk
  • php中header的用法
  • 政府划入资产会计处理
  • 公众号 企业
  • 员工购买住房公积金申请
  • 金融负债期末可以转出吗
  • 红字发票什么作用
  • php7.0新特性
  • 红嘴牛文鸟图片
  • 损益类科目调整影响所得税吗为什么
  • mysql详细教程
  • 小规模季度等于几个月
  • 税局代个人开增值税普通票样板
  • 办公室装修费多少钱可以一次性入账
  • 报账单大写金额负数填写方式
  • 一行的代码
  • 增值税防伪税控系统
  • 金银首饰以旧换新会计处理
  • 工程的直接成本包括哪些内容
  • 增值税是主税吗
  • 公司费用怎么做账
  • 残料入库计入
  • 委托加工业务的财务职责
  • 个税和社保有什么区别
  • 以前年度多计提的税金怎么调整
  • 发票丢失记账联入账
  • 股东变更需要哪些资料和手续
  • 建账时都要建哪些科目
  • mysql跨服务器查询语句
  • 用sql语句实现分页效果
  • win7还能用几年
  • mac itunes
  • 安装和配置eclipse集成开发环境
  • 删除隐藏文件命令
  • linux打包压缩文件的命令
  • win7怎么查是不是正版
  • 如何更改win10管理员账户
  • pdf在电脑上打开
  • 学习软件
  • 了不起的狐狸爸爸
  • shell 正则表达式 *什么意思
  • jquery的实现原理
  • shell 整数赋值
  • python爬虫工作内容
  • 介绍一个简单的实验
  • 房地产预缴土增值税
  • 政府免费
  • 网上查询公司营业执照
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设