`
openxtiger
  • 浏览: 151763 次
  • 性别: 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
分享到:
评论

相关推荐

    《JavaScript程序设计案例教程》课件(共13章)第1章 JavaScript程序设计案例教程.pdf

    《JavaScript程序设计案例教程》课件(共13章)第1章 JavaScript程序设计案例教程.pdf《JavaScript程序设计案例教程》课件(共13章)第1章 JavaScript程序设计案例教程.pdf《JavaScript程序设计案例教程》课件(共13章)第...

    JavaScript程序设计

    JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计JavaScript程序设计...

    javascript DOM高级程序设计 及 javascript 设计模式

    在吃透了前面所说的书之后,接下来两本书的顺序已经无关紧要了,《JavaScript DOM高级程序设计》(注意和《JavaScript 高级程序设计》相区别)和《JavaScript设计模式》,这两本都是重量级的书,能让你的JS技术上一...

    Head Frist JavaScript 程序设计.pdf

    《Head First JavaScript程序设计》是一本专为初学者准备的JavaScript入门教材。本书由埃里克·T.弗里曼和伊丽莎白·罗布森撰写,中文版由袁国忠翻译,隶属于图灵程序设计丛书。该书的特点在于其活泼的语言风格和...

    JavaScript权威指南第五版(JavaScript_The_Definitive_Guide_5th.chm)

     《JavaScript权威指南》是JavaScript程序设计者的完整指南和参考手册。对于使用最新的、遵守标准的Web浏览器(如Internet Explorer 6、Netscape 6和Mozilla)的开发者,它尤其有用。HTML作者可以从中学习如何用...

    JavaScript设计模式与开发实践.pdf

    "JavaScript设计模式与开发实践.pdf" 本书《JavaScript设计模式与开发实践》是JavaScript语言的设计模式和开发实践的指南,旨在帮助初、中、高级Web前端开发人员和想往架构师晋级的中高级程序员,掌握JavaScript...

    Javascript 程序设计基础教程(第2版)_习题答案

    JavaScript是一种广泛...总的来说,"JavaScript程序设计基础教程(第2版)_习题答案"涵盖了JavaScript的基础知识和现代特性,通过解答习题,学习者将能够熟练掌握JavaScript编程,从而能够创建交互式的网页和应用程序。

    Javascript程序设计教程-电子教案

    JavaScript程序设计教程是针对编程初学者和进阶者的一份详尽的教学资料,由李林和施伟伟两位专家编写。这份教程以PPT的形式,深入浅出地讲解了JavaScript的核心概念、语法特性以及实际应用,旨在帮助学习者掌握这门...

    学用JavaScript设计模式

    书中不仅介绍了JavaScript中经典和现代的设计模式,还包括了针对不同JavaScript开发框架(如MVC、MVP、MVVM)的设计模式,以及最新的模块化JavaScript设计模式(AMD、CommonJS、ES Harmony)和jQuery中的设计模式。...

    JavaScript 设计模式 azw3

    然后,集中介绍了很多流行的设计模式在JavaScript中的应用,包括Module(模块)模式、Observer(观察者)模式、Facade(外观)模式和Mediator(中介者)模式;最后,还探讨了模块化的JavaScript模式、jQuery及其插件...

    JavaScript课程设计及其课程项目实战.zip

    Javascript 第二章 JavaScript语句和函数 Javascript 第三章 JavaScript常用对象 Javascript 第四章 JavaScript高级对象 Javascript 第五章 文档对象模型 Javascript 第六章 JavaScript事件及应用 Javascript 第七章...

    Javascript 高级程序设计(第3版)超清中文PDF

    无论你是初学者还是经验丰富的开发者,都能从中受益匪浅,提升自己的JavaScript技能,从而更好地应对现代Web开发的挑战。 总之,这本书覆盖了JavaScript的各个方面,从基础到高级,从理论到实践,是每个JavaScript...

    JavaScript开发课程设计校园新闻微信小程序源代码.zip

    JavaScript开发课程设计校园新闻微信小程序源代码,JavaScript开发课程设计校园新闻微信小程序源代码JavaScript开发课程设计校园新闻微信小程序源代码JavaScript开发课程设计校园新闻微信小程序源代码JavaScript开发...

    JavaScript+jQuery程序设计 源码

    通过分析和实践这个"JavaScript+jQuery程序设计 源码",学习者不仅能巩固JavaScript和jQuery的基础知识,还能提升实际项目开发经验,尤其是处理网页交互和动态效果的能力。同时,这也将有助于理解和应用更多高级特性...

    基于javascript的web网站设计

    基于javascript的web页面设计

    Web前端网页设计作业-个人网页(html+css+javascript)

    在本项目中,"Web前端网页设计作业-个人网页(html+css+javascript)"是一个适合初学者的实践项目,旨在帮助学习者掌握Web前端开发的基本技能。这个项目包含了多个页面,如个人主页、个人博客、轮播相册、魔方相册、...

    javascript网页设计期末作业 购物网站

    这其实是我的期末作业,上传到网上是为了造福广大计算机专业的同学们∠( ᐛ 」∠)_ 网页共分为五个子网页,分别为: 1.登录页面 2.主页 3.购物车 4.留言板 5....其中主页完成度最高,可以单独拿出来使用(不过需要删掉...

    javascript经典电子教案

    javascript经典电子教案,初学者的必备武器,老手的查询资料。

Global site tag (gtag.js) - Google Analytics