标签:
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