javascript prototype

 1 <script>
 2 var Person=function(){}
 3 var p=new Person();
 4 console.log(p.__proto__==Person.prototype)//true
 5 //创建对象的三个步骤
 6 /**
 7 *1.var p={}
 8  2.p.__proto__=Person.prototype
 9  3.Person.call(this);
10 */
11 Person.prototype.say=function(){console.log("person say")}
12 /**
13 每个对象内部都存在一个__proto__,当我们访问一个属性的时候,如果内部
14 不存在,则会去__proto__去找,而__proto__又会去她自己的__proto__去找
15 默认__proto__不公开,火狐是例外
16 */
17 //p.say();
18 //复杂例子
19 Person.prototype.salary=5000;
20 var Programmer=function(){};
21 Programmer.prototype=new Person();
22 Programmer.prototype.writeCode = function () {
23             console.log("programmer writes code");
24         };
25 Programmer.prototype.salary=500;
26 
27 p=new Programmer();//p.__proto__==Programmer.prototype p.__proto__.__proto__=Person.prototype
28 p.say();
29 p.writeCode();
30 console.log(p.salary);
31 //通过prototype可以实现javascript的继承
32 
33 </script>

 

郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。