call和apply的用法以及apply的一些妙用

关于call和apply:

           实际上是改变了函数的作用域,也可以用来实现继承。


var name = "xiaoming";
    var a = function () {
        alert(this.name);
    };
    var b = {
      name: "xiaohua"
    };
    a.call(b)

这里可以看到,方法a在b上面运行了。

var name = "xiaoming";
    function say() {
        this.sayName = function(){
            alert(this.name);
        }
    }
    function Student(name){
        this.name = name;
        say.apply(this);
    }
    var xiaoming = new Student("xiaoming");
    xiaoming.sayName();

在构造函数Student里面,我们用apply继承了say,所以用构造函数构造出来的对象都会有sayName方法。

apply和call只是传入参数不一样而已。apply传入的第二个参数是一个数组,这一点可以有很多妙用。

比如:

 Array.prototype.push.apply(arr1,arr2);

可以实现将arr2直接加到arr1后面。

Array.prototype.splice(arr1,[index,0].concat(arr2));

实现了将arr2插入arr1的index位置。

Math.max.apply(null,arr);  


实现了用Math.max方法找出arr中的最大值。



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值