标签:
apply:方法能劫持另外一个对象的方法,继承另外一个对象的属性. 接受的参数是一个字符串。
call:和apply的意思一样,只不过是参数列表不一样. 接收的参数是一个数组。
例如:
<script> window.firstName = "diz"; window.lastName = "song"; var myObject = {firstName: "my", lastName: "Object"}; function HelloName(){ console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); } HelloName.call(window); HelloName.call(myObject); </script> 运行结果为: Hello diz song glad to meet you! Hello my Object glad to meet you!
HelloName方法调用window或myObject中的对象属性。
<script type="text/javascript">
/*定义一个人类*/
function Person(name,age)
{
this.name=name;
this.age=age;
}
/*定义一个学生类*/
functionStudent(name,age,grade)
{
Person.apply(this,arguments);
this.grade=grade;
}
//创建一个学生类
var student=new Student("qian",21,"一年级");
//测试
alert("name:"+student.name+"\n"+"age:"+student.age+"\n"+"grade:"+student.grade);
//大家可以看到测试结果name:qian age:21 grade:一年级
//学生类里面我没有给name和age属性赋值啊,为什么又存在这两个属性的值呢,这个就是apply的神奇之处.
</script>
标签:
原文地址:http://www.cnblogs.com/gide/p/4503267.html