`
openxtiger
  • 浏览: 147521 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

[原创]javascript 天才的设计者 (持续更新)

 
阅读更多

Javascript对象创建过程:

  JavaScript语言没有类的概念,除了基本类型(Number、String、booleans、null和undefined)之外,一切都是对象。

 

 

  1. 创建一个简单的对象,可以理解为空对象
  2. 将隐藏的__proto__属性指向构造函数的prototype对象
  3. 执行构造函数,并为构造函数中this提到的创建新的对象。
Javascript动态属性和原型属性:
  Javascript创建一个新的对象时,只会为“this提到的创建新的对象”在堆里面分配内存空间,而__proto__属性所对应对象(就是构造函数的prototype对象)其实是一个共享对象。所有创建新对象都会共享这个prototype对象。当访问新对象的属性时,如果新对象本身不含有此属性(含有此属性表示构造函数在用this提及的属性,或对象动态创建属性,可以用hasOwnProperty判断),就会访问共享的prototype对象中含有的属性。
说了这么多,还是没说到重点,所以神奇的重点是:

我们自己定义的对象,如果是在构造函数的是prototype对象定义属性和方法,这些属性和方法将会被所有通过这个构造函数new的对象共享。但这些共享的属性和方法是不能被改变的。我们改变对象的某个属性时,其实是为对象创建一个动态属性。这时才为这个对象属性分配空间。这就是javascript对象的奥秘。

顺便提一句,jQuery就是应用这一个特性,所以虽然jQuery的方法越定义越多,即使创建无数jQuery对象也不会害怕内存浪费了。但jQuery 扩展,请不要添加成员变量,详细请看http://openxtiger.iteye.com/blog/1631022



 

1
3
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics