我认为编程也是随着科技的发展实现,高效性,简介性的重要理念。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语言我个人感觉是最有意思的了,我也是一个初学者,遇到问题,喜欢在博客上分享,
也希望能帮到大家。
一个初学者,有什么不足或者纰漏的话,希望在下面评论出来,相互学习,共同进步。
--主页传送门--