经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » JavaScript » 查看文章
JS中call(),apply(),bind()函数的区别与用法详解
来源:jb51  时间:2022/12/12 8:57:00  对本文有异议

call()

介绍

通过提供一个新的this值给当前调用的函数/方法,从而改变this指向。

语法

  1. fn.call(this.Arg, arg1, arg2,...)

thisArg:当前调用函数this指向的对象
arg1, arg2:传递的其他参数(直接传给形参可不写)

特点

  • 可以直接调用函数—fn.call()
  • 可以改变被调用函数的this指向为指定的— fn.call(this.Arg)

返回值

使用调用者提供的值和参数调用该函数的返回值,也就是函数的返回值。若该方法没有返回值,则返回undefined

使用(主要应用)

通过使用call()来实现继承

  1. // 借用父构造函数继承属性
  2. // 父构造函数
  3. function Father(name, age) {
  4. this.uname = name
  5. this.age = age
  6. }
  7. // 子构造函数
  8. function Son(name, age) {
  9. Father.call(this, name, age)
  10. }
  11. var son = new Son('小明', 10)
  12. console.log(son); // Son {uname: '小明', age: 10}

apply()

介绍

apply-应用、运用的意思。
apply()-调用一个具有给定值的函数,以及以一个数组(或一个类数组对象)的形式提供的参数this,简单理解为调用函数的,fang'shi但是它可以改变this指向。

语法

  1. fn.apply(this.Arg, [argsArray])

thisArg:在fn函数运行时指定的this值,当不需要改变this指向时这里可以填null
argsArray:传递的值,必须包含在数组里面。

特点

  • 也是调用函数—fn.apply()
  • 可以改变函数内部的this指向—fn.apply(this)但是它的参数必须是数组(伪数组)

返回值

apply()的返回值就是函数的返回值,因为它就是调用函数。
使用调用者提供的值和参数调用该函数的返回值。若该方法没有返回值,则返回undefined

使用

  1. var a = {
  2. name: '小红'
  3. }
  4. function fn(arr) {
  5. console.log(this); // {name: '小红'}
  6. console.log(arr); // blackpink 传字符串就输出字符串传数字就输出数字
  7. }
  8. fn.apply(a, ['blackpink'])
  9. // fn.apply() // this->window arr->undefined

典型应用: 借助于数学内置对象求值。

  1. var arr = [1, 66, 3, 99, 4]
  2. // var max = Math.max.apply(null, arr) // 虽然这里的this指向不需要改变填null没有错
  3. var max = Math.max.apply(Math, arr) // 但是这里最好是让this指向函数的调用者是最合适的
  4. var min = Math.min.apply(Math, arr)
  5. console.log(max); // 99
  6. console.log(min); // 1

bind()

介绍

bind:绑定、捆绑
bind():不会调用函数,但是也能改变函数内部的this指向

语法

  1. fn.bind(thusArg, arg1, arg2, ...)

thisArg:在fn函数运行时指定的this值
arg1, arg2:传递的其他参数

特点

  • 不会调用原来的函数,不会立即调用
  • 可以改变原来函数内部的this指向;
  • 返回的是原函数改变this之后产生的新函数

返回值

  • 返回由指定的this值和初始化参数改造的原函数拷贝

使用

  1. var c = {
  2. name: '大华'
  3. }
  4. function fn() {
  5. console.log(this); // {name: '大华'}
  6. console.log(a + b); // 3
  7. }
  8. // fn.bind(c) // 这里不会有输出值
  9. var f = fn.bind(c, 1, 2)
  10. f() // 拷贝函数所以输出值用函数调用

典型应用
如果有的函数我们不需要立即调用,但是又想改变这个函数内部this指向,此时用bind(),eg:点击发送验证码60秒后才能二次点击

  1. <button>按钮</button>
  2. <button>按钮</button>
  3. <button>按钮</button>

  1. var btns = document.querySelectorAll('button')
  2. for (var i = 0; i < btns.length; i++) {
  3. btns[i].onclick = function() {
  4. this.disabled = true // 这个this指向的是调用者btn
  5. setTimeout(function() {
  6. // this.disabled = false; // 只用这一个不加bind的话会不管用,因为定时器里面的this指向的是window
  7. this.disabled = false // 此时这里的this指向的是当前点击的那个btn
  8. }.bind(this), 3000) // 这个this指向的是btn这个对象
  9. }
  10. }

call(),apply(),bind()的区别

三者相同点

  • 都可以改变函数内部的this指向

不同点

  • callapply 会调用函数,并且改变函数内部this指向;
  • callapply 的传参不一样,call 传参aru1, aru2...形式,apply 必须为数组形式 [arg]
  • bind 不会直接调用函数,但是可以改变函数内部this指向;

应用场景不同:

  • call 经常做继承;
  • apply 经常跟数组有关系,比如借助于数学对象实现数组最大最小值;
  • bind 不调用函数,但是还想改变this指向,比如改变定时器内部this指向;

以上既是JS中call(),apply(),bind()函数的区别与使用方法,更多关于这3个函数的使用方法请查看下面的相关链接

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号