原生js源码之bind方法,兼容性封装(IE8)

上次遇到IE8不能使用bind方法就处理了一下兼容,这次分享出来,看有人能有用不?

/**
 * Function.prototype.bind 方法的兼容性封装
 * func 要bind的函数
 * thisArg this指向对象
 */
function bind(func, thisArg) {
    var nativeBind = Function.prototype.bind;//获取Function原型上的bind
    var slice = Array.prototype.slice;
    if (nativeBind && func.bind === nativeBind) {//表示可以直接用Function原型上的bind
        return nativeBind.apply(func, slice.call(arguments, 1));
    }

	//走到这里就表示bind不能用,比如在IE8上就不能
	/**
		取func, thisArg后面的参数,比如是这样调用的bind(func,thisArg,'a',1,'c')
		那slice.call(arguments, 2) 取到的就是 后面3个实参组成的数组['a',1,'c']
	*/
    var args = slice.call(arguments, 2);
    return function () {
    	//args.concat(slice.call(arguments))是将bind时绑定的参数与调用时传的参数合并在一起。
    	var applyArgs = args.concat(slice.call(arguments));
        return func.apply(thisArg, applyArgs);
    };
}

来看一下使用方式:

var obj={
	name:'my name is obj',
	sayHi:function(){
		console.log(this.name)
	}
}
obj.sayHi();

var o = {
		name:'my name is o'
	};
var b = bind(obj.sayHi,o);
	b();

在IE8 上也能正常使用,如图:

 

当然如果觉得这样用起来不习惯,还是比较习惯  func.bind(obj,...args) 这种方式的话,就稍作修改:


if (!Function.prototype.bind) {
	Function.prototype.bind = function (thisArg) {
		if (typeof this !== "function") {
			throw new TypeError("Function.prototype.bind - what is trying to be bound is not callable");
		}
		var slice = Array.prototype.slice;
		var args = slice.call(arguments, 1),
		func = this;
	    return function () {
	    	//args.concat(slice.call(arguments))是将bind时绑定的参数与调用时传的参数合并在一起。
	    	var applyArgs = args.concat(slice.call(arguments));
	        return func.apply(thisArg, applyArgs);
	    };
	};
}

在IE8测试也是通过的,并且加了一个参数测试 :


var obj={
	name:'my name is obj',
	sayHi:function(a){
		console.log(this.name,"---",a)
	}
}
obj.sayHi();

var o = {
		name:'my name is o'
	};
var b = obj.sayHi.bind(o,'ppp');
	b();

结果如下:

 

帮到您的话点个赞吧!!

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程界小明哥

请博主喝瓶水,博主持续输出!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值