JavaScript之call、apply

    我认为编程也是随着科技的发展实现,高效性,简介性的重要理念。call和apply是JS中知识点少而又非常重要的。

call/apply

         作用:他们两个的作用相同,改变this指针的指向,借别人的方法实现自己的功能。

         区别:要说它们两个的区别有两个:1、书写不同。2、传参列表不同。call:需要把实参按照形参的个数传进去,

apply:传的是数组,是实参列表(arguments)。

        运用:

function Person(name,age){
this.name = name;
this.age = age;}
function Car(){}
var car = new Person.call(Car,"宝马","一年");
    在Person.call()里的第一个属性写父级构造函数,上述代码意思是借用Person的属性生产出一个Car()构造函数的对象。

call

function Door(color,doorStyle){
this.color = color;
this.style = style;}
function Window(material){
this.material = material;}
function Bed(bedStyle){
this.bedStyle = bedStyle;}
function Room(color,doorStyle,material,bedStyle){
Door.call(this,color,doorStyle);
Window.call(this,material);
Bed.call(this,bedStyle);
} var room = new Room("gray","木质","三开式","双人床");
apply
function Door(color,doorStyle){
this.color = color;
this.style = style;}
function Window(material){
this.material = material;}
function Bed(bedStyle){
this.bedStyle = bedStyle;}
function Room(color,doorStyle,material,bedStyle){
Door.apply(this,[color,doorStyle]);
Window.apply(this,[material]);
Bed.apply(this,[bedStyle]);
} var room = new Room("gray","木质","三开式","双人床");

JavaScript语言我个人感觉是最有意思的了,我也是一个初学者,遇到问题,喜欢在博客上分享,
也希望能帮到大家。 一个初学者,有什么不足或者纰漏的话,希望在下面评论出来,相互学习,共同进步。
     --主页传送门--
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值