当前位置: 首页 > news >正文

企业网站免费推广方案h5免费制作网站模板

企业网站免费推广方案,h5免费制作网站模板,设计效果图用什么软件哪个好,长沙部分风险区域调整之前我们说的都是代码内 this 的默认指向今天我们要来说一下如何能改变 this 指向也就是说, 你指向哪我不管, 我让你指向哪, 你就得指向哪开局在函数的原型( Function.prototype ) 上有三个方法callapplybind既然是在函数的原型上, 那么只要是函数就可以调用这三个方法&#xf…

之前我们说的都是代码内 this 的默认指向

今天我们要来说一下如何能改变 this 指向

也就是说, 你指向哪我不管, 我让你指向哪, 你就得指向哪

开局

在函数的原型( Function.prototype ) 上有三个方法

call

apply

bind

既然是在函数的原型上, 那么只要是函数就可以调用这三个方法,他们三个的作用就是改变函数的 this 指向

接下来咱们便开始介绍这三个方法

准备一个函数

const obj = { name: '对象' }
const arr = [ 100, 200, 300 ]function fn(a, b) {console.group('fn 函数内的打印信息') console.log('a : ', a)console.log('b : ', b)console.log('this : ', this)console.groupEnd()
}fn(1, 2)

直接调用函数,按照 this 指向规则, 该函数内的 this 会指向 window

  • 1 是传递给形参 a 的数据

  • 2 是传递给形参 b 的数据

call 方法

语法: 函数.call( 函数内的 this 指向, 给函数传递的参数, 给函数传递的参数 )

作用: 改变函数内的 this 指向

利用 call 调用 fn 函数,此时 obj 就是 fn 函数内的 this 指向

1 是传递给形参 a 的数据

2 是传递给形参 b 的数据

apply 方法

语法: 函数.apply( 函数内的 this 指向, 数组类数据结构 )

作用: 改变函数内的 this 指向

其实 apply 本质上和 call 方法没有区别,只是给函数传递参数的方式不一样 ,apply 的第二个参数是一个数组类的数据结构, 只要是按照索引排列即可

该数据结构内的每一个依次是给函数进行形参赋值的数据

利用 apply 调用 fn 函数,此时 arr 就是 fn 函数内的 this 指向,第二个参数是一个数组

该数组内 [0] 数据是传递给形参 a 的数据

该数组内 [1] 数据是传递给形参 b 的数据

bind 方法

语法: 函数.bind( 函数内的 this 指向, 给函数传递的参数, 给函数传递的参数 )

作用: 改变函数内的 this 指向

其实 bind 本质上和 call 方法没有区别,但是 bind 不会立即调用函数,而是返回一个被锁定好 this 的新函数

利用 bind 调用 fn 函数,此时 obj 就是你想设置的 fn 函数内的 this 指向

100 是传递给形参 a 的数据

200 是传递给形参 b 的数据

但是, 其实并不会立即执行 fn 函数,而是根据 fn 函数复刻了一份一模一样的函数,新函数复制给了 res 变量,res 函数内的 this 被锁定为了 obj.

通过浏览器查看我们会发现 fn 函数并没有被调用,那是因为 bind 本身就不会调用 fn 函数,如果想指向, 需要通过 res 变量调用

重构

上面我们介绍了一下三个方法的用法,如果你能掌握好, 那么接下来就来看看这三个方法是如何实现的吧

call 方法重构

这样, 我们的 call 重构就完成了

apply 方法重构

这个其实和 call 方法是差不多的, 只是参数不一样了而已,只是根据调用方式的不同, 我们接受参数不在需要 ...args, 直接接收即可

bind 方法重构

这个方法其实也是非常简单,只要利用一下之前重构好的 call 或者 apply 方法都可以

此时 bind 的重构就完成了,是不是很简单呢!

http://www.yayakq.cn/news/407212/

相关文章:

  • 网站开发程序用什么好优化型网站模板
  • 网站开发有侵权吗怎样建网站联系方式
  • 网站开发费会计分录代理上网
  • net开发网站建设电子杂志制作app
  • 网站开发公司怎么建服务器深圳龙霸网站建设物三
  • 网站建设骗开封网站开发
  • 有效的网站推广方案桔子建站
  • 电话约建设网站 客户不用模板 网站
  • 响应式网站示例为什么做的网站要续费
  • 网站设计扁平化今天最新新闻
  • 淘宝网网页版登录官网登录暴疯团队seo课程
  • 制作企业网站的软件哪些网站是php做的
  • 长治网站建设哪家好经济型网站建设
  • 网站备案为什么这么慢app制作公司十强
  • 华润置地建设事业部网站哈尔滨网页案例分析
  • 南京网站建设哪家好上海网站建设-网建知识
  • 河南网站推广优化公司哪家好做电商网站需要会些什么条件
  • 外包网站建设价格公司网站建设有用吗
  • 上海 宝安网站建设 网络服务平陆县网站建设
  • 网站建设上传视频教程网站推广产品
  • tp5做企业网站为你做的网站
  • 网站打不开原因七冶建设集团网站
  • 上海商地网站建设公司用万网建设网站教程视频
  • 中国精品课程网站wordpress图片并排
  • 账号权重查询入口站长工具cent os7 wordpress
  • 网站设计工作室公司手机怎么登录微信网页版
  • 企业网站2000元中国建设银行笔试确认网站
  • 网站建设与制作设计公司搜索引擎内部优化
  • 免费做情网站山东金城建设网站
  • 知乎网站内容建设的逻辑网站系统维护