全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

浅谈JavaScript中的apply/call/bind和this的使用

fun.apply(context,[argsArray])

立即调用fun,同时将fun函数原来的this指向传入的新context对象,实现同一个方法在不同对象上重复使用。

context:传入的对象,替代fun函数原来的this;

argsArray:一个数组或者类数组对象,其中的数组参数会被展开作为单独的实参传给 fun 函数,需要注意参数的顺序。

fun.call(context,[arg1],[arg2],[…])

同apply,只是参数列表不同,call的参数需要分开一个一个传入。如果不知道参数个数,则使用apply。

使用:

Math.max()    //只接收单独的参数,通过下面的方法可以在数组上面使用max方法:
Math.max.apply(null, array);    //会将array数组参数展开成单独的参数再传入
Array.prototype.push.apply(arr1,arr2);    //将一个数组拆开push到另一个数组中;不用apply则会将后续数组参数当成一个元素push进去。
Array.prototype.slice.call(arguments);    //在类素组对象上使用slice方法

function isArray(obj){
  return Object.prototype.toString.call(obj) === '[object Array]' ;
}  //验证是否是数组


fun.bind(context,[arg1],[arg2],[…])

使fun方法执行的context永不变。

arg1:要传递到新函数的参数列表

返回一个函数供后续调用,其函数体和原函数fun一样,但新函数的this指向新传入的context对象。新函数会具有bind方法指定的初始参数arg1/arg2...,后续调用新函数时的实参要往已有参数的后面排。

//原来的函数有4个参数
var displayArgs = function (val1, val2, val3, val4) {
  console.log(val1 + " " + val2 + " " + val3 + " " + val4);
}
var emptyObject = {};
// 生成新函数时bind方法指定了2个参数,则新函数会带着这个两个实参
var displayArgs2 = displayArgs.bind(emptyObject, 12, "a");
// 调用时传入另2个参数,要在bind方法传入的2个实参后面
displayArgs2("b", "c");
// Output: 12 a b c

事件处理函数中使用bind:

var obj = {
  arg1 : 1,
  attach: function(){
    //var self = this; 普通传入this 的方法
    $('xxx').on('click',function (event) {
      console.log(this.arg1);//若不绑定this,回调函数中的this常指目标元素
     }.bind(this));  //使用bind方法绑定this
  }
}    


使用bind()方法改写slice()方法:

var _Slice = Array.prototype.slice;
var slice = Function.prototype.call.bind(_Slice);
slice(…);

bind()兼容Ie5~ie8处理

if (!Function.prototype.bind) {
  Function.prototype.bind = function(context) {
    var self = this, // 调用bind方法的目标函数
    args = arguments;
    return function() {
      self.apply(context, Array.prototype.slice.call(args, 1));//参数个数不确定时用apply
    }
  }
}   

一般情况下setTimeout()的this指向window或global对象。当使用类的方法时需要this指向类实例,就可以使用bind()将this绑定到调用对象,而不用传入self方式传入this。

this

this对象是在函数运行时基于函数的执行环境绑定的:在全局函数中,this等于window,而当函数被当作某个对象的方法调用时,this等于那个对象。

判断方法:this和定义在哪儿无关,函数运行时,如果有. 运算符,this指.前的对象;如果没有,this指window。若new关键字调用时,指代新对象。有apply/call/bind时,指代第一个参数。

/*例1*/
function foo() {
  console.log( this.a );
} 
var obj2 = {
  a: 42,
  foo: foo
};
var obj1 = {
  a: 2,
  obj2: obj2
};
obj1.obj2.foo(); // 42;当foo函数被调用时,其本身是归obj2所拥有
/*例2*/
function foo() {
  console.log( this.a );
} 
var obj = {
  a: 2,
  foo: foo
};
var bar = obj.foo;   // bar引用foo函数本身
var a = "global";   // 全局对象的属性
bar();        // "global" ;  

在一个HTML DOM事件处理程序里面,this始终指向这个处理程序被所绑定到的DOM节点。


# call  # apply  # bind  # 区别  # js  # JavaScript中call  # bind的区别与实现  # 一文了解JavaScript中call/apply/bind的使用  # 一文搞懂JavaScript中bind  # call的实现  # JavaScript手写call  # bind方法  # JS 函数的 call、apply 及 bind 超详细方法  # JavaScript函数之call、apply以及bind方法案例详解  # 详解JS中的this、apply、call、bind(经典面试题) 


相关文章: 小型网站建站如何选择虚拟主机?  电商网站制作多少钱一个,电子商务公司的网站制作费用计入什么科目?  智能起名网站制作软件有哪些,制作logo的软件?  高配服务器限时抢购:企业级配置与回收服务一站式优惠方案  高防网站服务器:DDoS防御与BGP线路的AI智能防护方案  如何快速打造个性化非模板自助建站?  制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?  ,想在网上投简历,哪几个网站比较好?  建站主机CVM配置优化、SEO策略与性能提升指南  制作网站的基本流程,设计网站的软件是什么?  建站主机与服务器功能差异如何区分?  内网网站制作软件,内网的网站如何发布到外网?  大型企业网站制作流程,做网站需要注册公司吗?  高性能网站服务器部署指南:稳定运行与安全配置优化方案  招贴海报怎么做,什么是海报招贴?  网站制作价目表怎么做,珍爱网婚介费用多少?  网站制作怎么样才能赚钱,用自己的电脑做服务器架设网站有什么利弊,能赚钱吗?  如何快速生成凡客建站的专业级图册?  如何选择长沙网站建站模板?H5响应式与品牌定制哪个更优?  如何做网站制作流程,*游戏网站怎么搭建?  如何在Golang中使用replace替换模块_指定本地或远程路径  建站之星后台管理:高效配置与模板优化提升用户体验  建站之星如何快速生成多端适配网站?  如何优化Golang Web性能_Golang HTTP服务器性能提升方法  如何快速建站并高效导出源代码?  网站插件制作软件免费下载,网页视频怎么下到本地插件?  香港服务器部署网站为何提示未备案?  如何通过老薛主机一键快速建站?  制作电商网页,电商供应链怎么做?  如何在IIS管理器中快速创建并配置网站?  实例解析Array和String方法  文字头像制作网站推荐软件,醒图能自动配文字吗?  小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?  如何在IIS中配置站点IP、端口及主机头?  临沂网站制作企业,临沂第三中学官方网站?  怀化网站制作公司,怀化新生儿上户网上办理流程?  如何用景安虚拟主机手机版绑定域名建站?  html制作网站的步骤有哪些,iapp如何添加网页?  红河网站制作公司,红河事业单位身份证如何上传?  淘宝制作网站有哪些,淘宝网官网主页?  儿童网站界面设计图片,中国少年儿童教育网站-怎么去注册?  企业网站制作费用多少,企业网站空间一般需要多大,费用是多少?  建站之星ASP如何实现CMS高效搭建与安全管理?  购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?  如何用已有域名快速搭建网站?  如何解决VPS建站LNMP环境配置常见问题?  手机网站制作平台,手机靓号代理商怎么制作属于自己的手机靓号网站?  如何选择高效便捷的WAP商城建站系统?  如何快速查询网站的真实建站时间?  如何通过西部建站助手安装IIS服务器? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。