最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

javascript中call与apply以及bind有哪些不同

来源:动视网 责编:小采 时间:2020-11-27 20:00:55
文档

javascript中call与apply以及bind有哪些不同

javascript中call与apply以及bind有哪些不同:这次给大家带来javascript中call与apply以及bind有哪些不同,javascript中call与apply以及bind使用的注意事项有哪些,下面就是实战案例,一起来看一下。首先补充严格模式这个概念,这是ES5中提出的,只要写上:use strict就是告诉当前浏览器,
推荐度:
导读javascript中call与apply以及bind有哪些不同:这次给大家带来javascript中call与apply以及bind有哪些不同,javascript中call与apply以及bind使用的注意事项有哪些,下面就是实战案例,一起来看一下。首先补充严格模式这个概念,这是ES5中提出的,只要写上:use strict就是告诉当前浏览器,


这次给大家带来javascript中call与apply以及bind有哪些不同,javascript中call与apply以及bind使用的注意事项有哪些,下面就是实战案例,一起来看一下。

首先补充严格模式这个概念,这是ES5中提出的,只要写上:

“use strict”

就是告诉当前浏览器,接下来的JavaScript代码将按照严格模式进行编写。

function fn() { 
console.log(this); 
}

fn.call(); // 普通模式下this是window,在严格模式下this是undefined
fn.call(null); // 普通模式下this是window,在严格模式下this是null
fn.call(undefined); // 普通模式下this是window,在严格模式下this是undefined
apply方法和call方法的作用是一模一样的,都是用来改变方法的this关键字,并且把方法执行,而且在严格模式下和非严格模式下,对于第一个参数是null/undefined这种情况规律也是一样的,只是传递函数的的参数的时候有区别。

function fn(num1, num2) {
 console.log(num1 + num2);
 console.log(this);
}fn.call(obj , 100 , 200);fn.apply(obj , [100, 200]);123456

call在给fn传递参数的时候,是一个个的传递值的,而apply不是一个个传的,而是把要给fn传递的参数值同一个的放在一个数组中进行操作,也相当于一个个的给fn的形参赋值。

bind方法和apply、call稍有不同,bind方法是事先把fn的this改变为我们要想要的结果,并且把对应的参数值准备好,以后要用到了,直接的执行即可,也就是说bind同样可以改变this的指向,但和apply、call不同就是不会马上的执行。

var tempFn = fn.bind(obj, 1, 2); 
tempFn();

第一行代码只是改变了fn中的this为obj,并且给fn传递了两个参数值1、2,但是此时并没有把fn这个函数给执行,执行bind会有一个返回值,这个返回值tempFn就是把fn的this改变后的那个结果。

注意:bind这个方法在IE6~8下不兼容。

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

spring boot的定时任务应该如何使用

javascript中call详解

文档

javascript中call与apply以及bind有哪些不同

javascript中call与apply以及bind有哪些不同:这次给大家带来javascript中call与apply以及bind有哪些不同,javascript中call与apply以及bind使用的注意事项有哪些,下面就是实战案例,一起来看一下。首先补充严格模式这个概念,这是ES5中提出的,只要写上:use strict就是告诉当前浏览器,
推荐度:
标签: 有什么 区别 call
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top