JavaScript - prototype 和 call 的理解

prototype:

其实对象直接通过 【object.属性/方法】  来定义方法和属性也是可以的,但是会变成静态属性和静态方法,也就是调用的时候也是通过“.”来调用的。
但如果通过prototype来定义,那么是不行的,必须先实例化属性才可以调用
另外也不一定必须用prototype来定义实例方法和实例属性,可以在函数体中

var aa = function()
{
    //使用【this.属性/方法】来定义。    
}


call

1、【方法.call(另一个方法,参数1,参数2,参数3…)】
这种就是单纯的替换和传递参数的作用

var add = function(a,b)
{
    alert("我是add");
    alert(a + b);
}

var sub = function(a,b)
{
    alert("我是sub");
    alert(a -  b);
}

add.call(sub,3,1); //这个例子的意思是将add替换sub,所以结果是4

2、【object.call】直接通过对象进行call操作是继承的意思

【Animal.call(this,name);】说明Animal代替了所有的Cat,也就是说Cat对象目前可以调用Animal中所有的对象和属性,谁叫他被代替了

 

var Animal = function(name)
{
    this.name  = name;
    this.showName = function()
    {
        alert(this.name);
    }
}

var Cat = function(name)
{ 
    alert("123");
    Animal.call(this,name);    
}

var cat = new Cat("cat"); //对象创建时,自动执行函数内的代码块

cat.showName();

前者代替/传承后者,后者继承前者。然后执行操作前者的函数

【object.方法.call(另一个对象,参数1,参数2,参数3…)】
call的作用是将【object.方法】在【另一个对象】的【函数体】中执行,并且传入参数。有点继承和委托

var Cat = function()
{
    this.name  = "cat";
}

var animal = new Animal();
var cat = new Cat();

animal.showName.call(cat,"HelloWorld");

 




转载于:https://www.cnblogs.com/CyLee/p/5324623.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值