Javascript 对象继承(1)

object literal方式创建对象

![ object literal 方式创建的对象]
object literal chrome 输出
  • b 是一个以 Object.prototype 为原型的对象
  • b.__proto__ 指向的是 Object.prototype

原型继承

construct function

every JavaScript function (except functions returned by the ECMAScript 5 Function.bind() method) automatically has a prototype property. The value of this property is an object that has a single nonenumerable constructor property. The value of the constructor property is the function object.
---David Flanagan. “JavaScript: The Definitive Guide.” iBooks.

construct function.png
construct function chrome.png
  • Employee是个函数
  • 根据上面的文字跟chrome输出,可以看出Employee.prototype是 object,并有一个construct function就是其本身
  • Employee.__proto__function() {}

prototype based inheritance

Object.create()

Object.create inherit.png
Object.create inheite chrome.png
  • Manager.prototype 只是一个原型为Employee.prototype的object

一个中间过渡的func F

F() inherit.png
F() inherit chrome.png

关于以上两种方式的继承:

为什么使用中间函数F实现继承.png
为什么使用中间函数F实现继承 chrome.png
  • 使用第二种B.prototype = new A();方式,会报上图的错误,你需要改成B.prototype = new A("");的方式,比较繁琐
  • **使用第一种 B.prototype = new F();的方式继承 **,不会出现上图中的错误,可以把它封装成函数,方便使用

Javascript的坑

可以看上面第二种方式 B.prototype.constructor = B;, 看到这句刚开始有点不理解:
我的想法是, F.prototype = A.prototype; B.prototype = new F(); ,这句让 B.prototypeA.prototype原型的一个对象,而一个A.prototype原型的对象,继承成了一个construct function的方法,那使用 B.prototype.constructor = B; 不是把 prototype chain 上的construct function 给修改了吗?
其实不是的。

从下面代码可以看出,从javascript对象取属性值时,会一次从prototype chain上找。但是给一个新属性赋值时,直接在本对象添加,而不是更改prototype chain上的值
![Uploading aa 跟 aa.proto同名属性 chrome_074940.png . . .]

aa 跟 aa.__proto__同名属性.png

aa 跟 aa.__proto__同名属性 chrome.png
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • You Don't Know JS: this & Object Prototypes Chapter 5: Pr...
    大橙子CZ阅读 3,805评论 0 2
  • 只卖同城 人民广场大庙附近 自提 最低价 不刀 浪费时间 喜欢的联系
    loveuyeah阅读 1,288评论 0 1
  • 《梦台》 镜花临媚掩红妆,风月残局落醉殇。 幽影余痴妃子梦,三音堪酒余思肠。 《屏台》 珠帘霓曲梦方醒,楼凤错眉兰...
    景黎阅读 2,224评论 2 11
  • 每天下班大部分时间会选择走路回来,劳累了一天,不想在熙熙攘攘的人群中骑着自行车风风火火挤出一条道。途中有一...
    Iria莹阅读 3,068评论 0 0

友情链接更多精彩内容