最新文章专题视频专题问答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
当前位置: 首页 - 科技 - 知识百科 - 正文

apply和call的方法介绍

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

apply和call的方法介绍

apply和call的方法介绍:apply和call的方法是一模一样的,都是用来改变方法的this关键字,并且把方法执行:而且在严格模式和非严格模式下对于第一个参数是null/undefined这种情况的规律是一样的;bind:这个方法在IE6-8下不兼容 ->和call和apply类似都是用来改变this关
推荐度:
导读apply和call的方法介绍:apply和call的方法是一模一样的,都是用来改变方法的this关键字,并且把方法执行:而且在严格模式和非严格模式下对于第一个参数是null/undefined这种情况的规律是一样的;bind:这个方法在IE6-8下不兼容 ->和call和apply类似都是用来改变this关


apply和call的方法是一模一样的,都是用来改变方法的this关键字,并且把方法执行:而且在严格模式和非严格模式下对于第一个参数是null/undefined这种情况的规律是一样的;

bind:这个方法在IE6-8下不兼容 ->和call和apply类似都是用来改变this关键字的

'use strict' //告诉当前浏览器接下来的js代码将按照严格模式进行编写var obj = {name:'张三'}function fn(num1,num2){
 console.log(num1+num2);
 console.log(this)
 }
 fn(100,200);
 //this ->window num1=100 num2=200fn.call(100,200);
 // this->100 num1 = 200 num2=undefined NaNfn.call(obj,100,200)
 //this->obj call在给fn传递参数的时候,是一个个传递值的,而apply不是一个个传,而是把要传递的参数值放在一个数组中进行操作。但是也相当于一个个的给fn的形参赋值fn.apply(obj,[100,200]);
 // 
 //预处理:事先把fn的this改变为我们想要的结果,并且把对应的参数值也准备好,以后要用到了,直接的执行即可。bind这里实现了预处理的效果var tempFn = fn.bind(obj,100,200);
 //只是改变了fn中的this为obj,并且给fn传递了两个参数值100和200,但此时并没有把fn这个函数执行,执行bind会有一个返回值,这个返回值tempFn就是我们把fn的this改变后的那个结果 
 tempFn();
 fn.call();
 //this->window 在严格模式下this->undefinedfn.call(null);
 //this->window 在严格模式下this->nullfn.call(undefined)
 //this->window 在严格模式下this->undefined

文档

apply和call的方法介绍

apply和call的方法介绍:apply和call的方法是一模一样的,都是用来改变方法的this关键字,并且把方法执行:而且在严格模式和非严格模式下对于第一个参数是null/undefined这种情况的规律是一样的;bind:这个方法在IE6-8下不兼容 ->和call和apply类似都是用来改变this关
推荐度:
标签: app 方法 介绍
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top