JavaScript面向对象编程深入分析.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
JavaScript面向对象编程深入分析

JavaScript面向对象编程深入分析(1) 2011-06-28 14:11 阮一峰 阮一峰的网络日志 我要评论(0) 字号:T | T 学习Javascript,最难的地方是什么?我觉得,Object(对象)最难。因为Javascript的Object模型很独特,和其他语言都不一样,初学者不容易掌握。 AD: 2013云计算架构师峰会精彩课程曝光 一. Javascript 面向对象编程:封装 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象。但是,它又不是一种真正的面向对象编程(OOP)语言,因为它的语法中没有class(类)。 那么,如果我们要把属性(property)和方法(method),封装成一个对象,甚至要从原型对象生成一个实例对象,我们应该怎么做呢? 1. 生成对象的原始模式 假定我们把猫看成一个对象,它有名字和颜色两个属性。 var Cat = { name : , color : } 现在,我们需要根据这个原型对象,生成两个实例对象。 var cat1 = {}; // 创建一个空对象 cat1.name = 大毛; // 按照原型对象的属性赋值 cat1.color = 黄色; var cat2 = {}; cat2.name = 二毛; cat2.color = 黑色; 2. 原始模式的改进 我们可以写一个函数,解决代码重复的问题。  function Cat(name,color){ return { name:name, color:color } } 然后生成实例对象,就等于是在调用函数: var cat1 = Cat(大毛,黄色); var cat2 = Cat(二毛,黑色); 3. 构造函数模式 为了解决从原型对象生成实例的问题,Javascript提供了一个构造函数(Constructor)模式。 所谓构造函数,其实就是一个普通函数,但是内部使用了this变量。对构造函数使用new运算符,就能生成实例,并且this变量会绑定在实例对象上。 比如,猫的原型对象现在可以这样写, function Cat(name,color){ this.name=name; this.color=color; } 我们现在就可以生成实例对象了。 var cat1 = new Cat(大毛,黄色); var cat2 = new Cat(二毛,黑色); alert(cat1.name); // 大毛 alert(cat1.color); // 黄色 alert(cat1.constructor == Cat); //true alert(cat2.constructor == Cat); //true Javascript还提供了一个instanceof运算符,验证原型对象与实例对象之间的关系。 alert(cat1 instanceof Cat); //true alert(cat2 instanceof Cat); //true 4. 构造函数模式的问题 构造函数方法很好用,但是存在一个浪费内存的问题。 请看,我们现在为Cat对象添加一个不变的属性type(种类),再添加一个方法eat(吃老鼠)。那么,原型对象Cat就变成了下面这样:  function Cat(name,color){ this.name = name; this.color = color; this.type = 猫科动物; this.eat = function(){alert(吃老鼠);}; }  var cat1 = new Cat(大毛,黄色); var cat2 = new Cat (二毛,黑色); alert(cat1.type); // 猫科动物 cat1.eat(); // 吃老鼠 alert(cat1.eat == cat2.eat); //false 能不能让type属性和eat()方法在内存中只生成一次,然后所有实例都指向那个内存地址呢?回答是可以的。 5. Prototype模式 Javascript规定,每一个构造函数都有一个prototype属性,指向另一个对象。这个对象的所有属性和方法,都会被构造函数的实例继承。 这意味着,我们可以把那些不变的属性和方法,直接定义在prototype对象上。  function Cat(name,color){ this.name = name; this.color = color; } Cat.prototype.type = 猫科动物; Cat.p

文档评论(0)

yaobanwd + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档