javascript 的call和apply方法

call和apply的作用基本上差不多,不同的是参数形式不一样。
call:调用一个对象的一个方法,以另一个对象替换当前对象。apply在对象继承方面的应用,不使用prototype,隐式的将父对象属性赋给了子对象
apply:应用某一对象的一个方法,用另一个对象替换当前对象。

   < script >
    
function  person1() {
      
this.name='sam';
    }

    person1.prototype.fun
= function () {
      alert(
this.name);
    }

    
function  person2() {
      
this.name='ruby';
    }

    
var  a = new  person1();
    
var  b = new  person2();
    a.fun.apply(b);
</ script >

< script >
    
function  O() {
        
this.name="Object";
    }

    
var  name = " Window " ;
    
function  M() {
        alert(
this.name);
    }

    
    
// Window
    window.M();
    
// Window
    M.call(window);
    
// Object
    M.call( new  O());
</ script >

< script >
    
function  father(n) {
      
this.name=n;
     }

     
function  child(cn,fn) {
      
this.childName=cn;
      father.apply(
this,new Array(fn));
     }
;
     
var  Child = new  child( " jeson " , " Mr jeson " );
     alert(Child.name
+ " ; " + Child.childName);
</ script >
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值