位置: 编程技术 - 正文

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

  • 代扣个人所得税怎么算
  • 档案室图书应该做哪个会计科目
  • 银行回单电子退库是什么意思
  • 国际货运代理可以开免税吗
  • 进销的单位不一样怎么办
  • 固定增长定价模型
  • 会计成本核算工作内容
  • 税收的组成
  • 国库集中支付行政运行
  • 半成品原材料报废会计处理怎么做?
  • 应收账款计提坏账准备是谨慎性原则吗
  • 个人去税务局能开什么类型的发票
  • 个人独资企业可以不开公户吗
  • 开票方开错发票
  • 货物销售价比采购价高
  • 小规模印花税怎么报
  • 公司自己的食堂需要办理食品经营许可证吗
  • 以前年度损益调整借贷方向
  • 暂估入库有时间限制吗
  • php多维数组转一维数组
  • 鸿蒙系统蓝牙耳机声音小怎么办
  • 在建工程进项税额转出
  • win10无法连接应用商店
  • 医疗保险在外地交了老家还要交吗
  • latex双栏图片
  • 解聘员工补偿金能拖欠吗
  • 前端打包后生成文件
  • vue3props用法
  • php的lamp
  • 计算机视角技术
  • pytorch1.5
  • 第十届蓝桥杯大赛个人赛省赛结果
  • bert数据增强
  • php charat
  • Python中如何定义一个变量
  • 新法典离职
  • 党费返还怎么记账
  • 资产负债表所有者权益怎么算
  • 合同资产要结转增值税吗
  • 出纳报销时应注意什么
  • 织梦怎么建站
  • 哪些凭证是免纳税的
  • 投资收益的主要形式有
  • 企业转钱给个人
  • 公款私存个人检讨
  • 电脑入账如何做凭证
  • 计算业务招待费扣除限额的基础包括营业外收入
  • 税控服务费减免月底怎样结转
  • 本月发生费用未支付会计处理
  • 利润分配未分配利润是净利润吗
  • 饭店房屋的租赁合同范本
  • 商品流通环节包括
  • 公司车过户给个人多久不用补税
  • 政府补贴的装修费是免税的吗
  • 国有独资企业董事会成员组成规定
  • 账上存货太多实收怎么办
  • 小规模企业自开收购牛发票增值税怎样申报
  • 可以自行开具增值税专用发票的行业有哪些
  • 认证测试方式有哪几种
  • 旅游企业相关服务案例
  • mysqlsum查询慢
  • 断电恢复
  • mysql join查询慢
  • centos中用户的基本属性
  • 64位win10预览版10565更新补丁KB3105208后蓝屏怎么办?
  • mac u 盘启动
  • centos7安装中文包
  • win10如何不升级系统
  • 解决出现的问题下一句,欢迎的语气
  • js中onunload
  • jquery文本框内容改变事件
  • js如何显示日期和时间
  • shell脚本实例精讲
  • nodejss
  • unity c+
  • 22号天蝎座的运势
  • android常见问题及解决方法
  • 广州税务局前局长是谁
  • 运输发票抵税多少个点
  • 江苏地税局官网网站
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设