JS为什么会有原型的概念?

开发 前端
因为早期的浏览器只能用来浏览,不具备与访问者互动的能力。比如,如果网页上有一栏"用户名"要求填写,浏览器就无法判断访问者是否真的填写了,只有让服务器端判断。

[[402108]]

因为早期的浏览器只能用来浏览,不具备与访问者互动的能力。比如,如果网页上有一栏"用户名"要求填写,浏览器就无法判断访问者是否真的填写了,只有让服务器端判断。

如果没有填写,服务器端就返回错误,要求用户重新填写,这太浪费时间和服务器资源了。

这个时候需要一门网页脚本语言,这种脚本语言能够完成一些简单的操作,比如判断用户有没有填写表单。刚好这个时候是向对象编程(object-oriented programming)最兴盛的时期,C++是当时最流行的语言,而Java语言也马上推出。

所以Javascript作者也受到了启发,Javascript里面所有的数据类型都是对象(object),这一点与Java非常相似。但是直接使用java的"继承"机制来实现,又觉得过于笨重,但是,Javascript里面都是对象,必须有一种机制,将所有对象联系起来。所以,javascript作者最后还是设计了"继承"。

但是,他不打算引入"类"(class)的概念,因为一旦有了"类",Javascript就是一种完整的面向对象编程语言了,这好像有点太正式了,而且增加了初学者的入门难度。

他考虑到,C++和Java语言都使用new命令,生成实例。

C++的写法是:

  1. ClassName *object = new ClassName(param); 

Java的写法是:

  1. Foo foo = new Foo(); 

这时,他想到C++和Java使用new命令时,都会调用"类"的构造函数(constructor)。他就做了一个简化的设计,在Javascript语言中,new命令后面跟的不是类,而是构造函数。

但是很快发现用构造函数生成实例对象,有一个缺点,那就是无法共享属性和方法。

每一个实例对象,都有自己的属性和方法的副本。这不仅无法做到数据共享,也是极大的资源浪费。

最终加入了prototype属性的引入

考虑到这一点,作者决定为构造函数设置一个prototype对象属性。

所有实例对象需要共享的属性和方法,都放在这个对象里面;那些不需要共享的属性和方法,就放在构造函数里面。

实例对象一旦创建,将自动引用prototype对象的属性和方法。

由于所有的实例对象共享同一个prototype对象,那么从外界看起来,prototype对象就好像是实例对象的原型,而实例对象则好像"继承"了prototype对象一样。

面试总结回答

  • JavaScript采用原型编程,所有对象都能共享原型上的方法,节省内存;
  • 同时基于原型这一实现思想,JavaScript通过找对原型链,方便地实现了继承。

这就是原型编程带来的2个最大好处!!!

参考资料

内容有最简化,如果需要看原始总结请查看阮一峰博客↓

http://ruanyifeng.com/blog/2011/06/designing_ideas_of_inheritance_mechanism_in_javascript.html

https://blog.csdn.net/daigualu/article/details/54772799

本文转载自微信公众号「前端人」,可以通过以下二维码关注。转载本文请联系前端人公众号。

 

责任编辑:武晓燕 来源: 前端人
相关推荐

2020-09-10 07:04:30

JSJavaScript 原型链

2020-08-02 22:54:04

Python编程语言开发

2019-12-02 14:22:01

浪费云计算支出

2013-01-15 09:41:45

编程语言

2017-03-09 11:15:18

LinuxRoot账户

2017-12-21 19:38:50

润乾中间表

2021-12-20 14:42:39

程序员职业技术

2022-07-26 23:43:29

编程语言开发Java

2013-01-24 09:44:44

数据库

2019-02-27 16:00:48

JS原型原型链对象

2015-11-04 09:57:18

JavaScript原型

2022-08-02 18:37:24

BI系统快照表

2020-10-15 13:19:24

为什么会存在乱码

2022-12-09 14:34:40

程序员工资离职

2022-01-10 10:05:33

键盘屏幕内存

2020-03-31 16:30:09

JS语言ES 6

2020-04-02 09:01:54

JSES 6开发

2015-05-18 15:08:08

多种程序设计语言程序设计语言

2012-05-02 15:56:20

PHP

2020-05-28 07:50:18

重排序happens-befCPU
点赞
收藏

51CTO技术栈公众号