位置: 编程技术 - 正文

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

发布时间:2024-02-27

推荐整理分享学习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延时加载方式)

  • 代开专用发票需要交城建税吗
  • 增值税相关政策
  • 增值税纳税义务发生时间的规定
  • 主营业务怎么计算
  • 另收取包装物押金
  • 黑盘报税流程视频教程
  • 提供给员工宿舍租赁 入账
  • 取得的进项发票当月不抵扣怎么做账
  • 存货取得的分录
  • 上年留抵税,次年抵扣分录
  • 个人所得税补缴不补会怎样
  • 小型微利企业减按25%计算应纳税所得额
  • 租车补贴记入工资的会计处理怎么做?
  • 帮对方公司垫付违法吗
  • 其他权益工具包含
  • 垫付资金成本
  • 经营租赁中出租人发生的初始直接费用是指
  • 进料加工出口退税计算 计划分配率
  • 工商年报财务数据怎么填
  • 怎么检查windows版本
  • 公司给员工的餐补有没有个税
  • 欠款利息收入如何入账
  • 错账按产生原因来看有两种
  • 刚毕业的学生可以买学生票吗
  • PHP:shell_exec()的用法_命令行函数
  • 如何把握售后租回交易的主要问题
  • pytorch复制模型
  • 所有者权益变动表范本
  • php正则表达式匹配字符串
  • yum安装php5
  • 斯坦福大学起源
  • vue开发环境配置
  • 小规模纳税人申报表模板
  • 03-JavaScript基础
  • 社保基数填错了 多扣多钱可以退款吗
  • 小规模纳税人采购需要发票吗
  • 公司注册流程百度百科
  • PostgreSQL教程(十六):系统视图详解
  • 哪些公司可以开电费发票
  • 烈士祭扫仪式
  • 跨年已付款发票未到会计分录
  • 预付款退回来了怎么做账
  • 公司代缴社保如何查询
  • 收到房租租金下什么科目
  • 投标保证金支付给谁
  • 赠送货物怎么做账
  • 成本收入率和收入成本率的区别
  • 简单介绍清明上河图
  • mysql基本介绍
  • xp系统玩英雄联盟出现win32
  • openstack 创建云主机,计算节点磁盘不足
  • vmware安装redhat6.5
  • vc运行程序exe停止工作怎么办
  • 设置pc
  • linux find命令忽略大小写
  • flashhelperservice.exe是什么程序
  • linux 消耗内存命令
  • grep命令用法
  • linux哪里好
  • cocos2dx游戏有哪些
  • html td 合并
  • js 单引号
  • nodejs获取ip
  • 安卓开发者有多少
  • javascript的相关应用
  • jQuery Mobile和HTML5开发App推广注册页
  • unity怎么弄游戏小地图
  • jquery常见问题
  • jquery事件处理有哪些
  • linux和windows互ping
  • js保存设置
  • 怎么向税务局举报不开票行为
  • 为什么要去山西
  • 江苏税务查询授权验证码
  • 安徽税务发票查询入口
  • 社保已经申报成功未缴费在哪交费
  • 深圳国税网上申报流程图
  • 税控盘离线开票时间超限是怎么回事
  • 税务筹划收费标准最新
  • 小规模纳税人的增值税怎么计算
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号