码迷,mamicode.com
首页 > 其他好文 > 详细

prototype 和 proto

时间:2016-07-03 17:25:16      阅读:108      评论:0      收藏:0      [点我收藏+]

标签:

prototype:

prototype 函数才有prototype 是对象类型 typeof Person.prototype --> ‘object‘ Function
创建一个Person类
function Person(){
this.age = 22;
this.name = ‘tony‘;
}

Person.prototype.headCount = 1;
  将对象共同拥有的属性写在prototype里面,节省内存。
    var p = new Person()//p1.constructor(p1的构造器) --> function Person()
console.log(p.headCount)// -->1
Person.prototype.headCount = 2;
console.log(p.headCount)// -->2
//js的类是伪类,本质上p1和Person没有关系,p1和Person.prototype才有关系
Person.name = 1234;
console.log(p.name)// --> tony

// __proto__(谷歌和火狐有,ie没有) p1和Person.prototype的联系 函数隐藏的属性
console.log(p.__proto__);// --> Object {headCount: 1} (Object是一个对象)
// p运行时和Person没有关系,p实例化出来之后,里面的变量有age、name 还有一个隐形的变量__proto__
// 当访问p.headCount时,p本身没有headCount这个变量,p就会通过__proto__去Person.prototype里面找
console.log(p.__proto__.headCount)// --> 2
//
Person.prototype.headCount = 3;
console.log(p.headCount)// -->3
//给Person.prototype重新赋值
Person.prototype = {call:‘hello ‘}
console.log(p.call)// -->undefined
console.log(p.headCount)// -->3
console.log(Person.prototype) // --> Object {call: "hello "}
var p1 = new Person()
console.log(p1.call)// --> hello
//结论:Person.prototype的改变对p没有影响,因为p.__proto__指向的是Person.prototype改变之前的对象,
//Person.prototype改变之后,之前的对象依然存在没有消失,所以p.call是undefined,p.headCount是3
//Person.prototype改变之后,只对改变以后新创建的对象有影响。

//查找属性的过程
console.log(p1.call)// --> hello
p1.call = ‘你好!‘;
console.log(p1.call)// --> 你好!
console.log(Person.prototype.call)// --> hello
//结论:p1.call = ‘你好!‘,给p1添加了call这个,p1自己就有了call这个属性,访问p1.call时,在p1里面
// 就找到了call,就不会再去Person.prototype里面去找


// 总结 prototype 和 proto的区别
// 1、prototype属性是公有的,只要是函数都有这个属性,都可以用。__proto__是私有的,是对象才有的,指向
// 构造函数的原型,用于研究,只有谷歌和火狐才能用

prototype 和 proto

标签:

原文地址:http://www.cnblogs.com/wvvv/p/5638187.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!