前端-JS基于原型面向对象(对象创建,继承,构造等)

来源:互联网 发布:淘宝店铺会员管理系统 编辑:程序博客网 时间:2024/05/21 06:14

JS
1,面向对象
2,js中没有类的概念,(面向对象,实际上就是对象之间的交互,要类干什么?)
3,js中没有类,如何创建对象?(对象就是,属性+方法),配图片
这里写图片描述
PS:
1,没有类的约束,对象比较自由
2,Javascript是一个基于原型实现的面向对象的语言

4,继承是面向对象的重要概念,js如何实现继承?
(继承,就是让两个对象建立关联),配图片
这里写图片描述
PS:
1,proto 属性指向的就是原型
2,对象dog 的原型是animal (注意:也是一个对象), 对象cat的原型也是animal 。
无论是dog还是cat ,都没有定义eat()方法, 那怎么可以调用呢?
当eat方法被调用的时候,先在自己的方法列表中寻找, 如果找不到,就去找原型中的方法, 如果原型中找不到, 就去原型的原型中去寻找…… 最后找到Object那里, 如果还找不到, 那就是未定义了。
这里的这几个对象肯定是通过proto建立了一个原型链! ,配图片
这里写图片描述

5,上面每新创建对象时都会有一个sayHello函数,浪费空间/效率
进阶1:
这里写图片描述

对应的实现链接:
这里写图片描述

进阶2(比进阶1更方便高效些):
这里写图片描述

本文再大牛文章基础上总结出来,详细内容,请看大牛文章:http://baijiahao.baidu.com/s?id=1573810527005724&wfr=spider&for=pc

原创粉丝点击