原型和原型链 - 草稿

. 原型

js中万物皆对象,(普通对象和函数对象)

Object.function是js自带的函数对象

1.举例prototype的属性

分析一下,上面这个例子!我们可以知道 People的类型是一个对象!

按照javascript的说法,function定义的这个Person就是一个Object(对象),而且还是一个很特殊的对象,这个使用function定义的对象与使用new操作符生成的对象之间有一个重要的区别。这个区别就是function定义的对象有一个prototype属性,使用new生成的对象就没有这个prototype属性,我们一般称为普通对象!

我们需要理解记忆以下的逻辑顺序:

Person是一个对象,它有一个prototype的原型属性(因为所有的对象都一prototype原型!)prototype属性有自己的prototype对象,而pototype对象肯定也有自己的constuct属性,construct属性有自己的constuctor对象,神奇的事情要发生了,这最后一个constructor对象就是我们构造出来的function函数本身!

2. 任何对象都有prototype属性

3.、下面我们不免有了疑问,学这么绕的东西干什么,它给我们最实际的用处就是我们可以用原型来创建对象的属性和方法!我们不用它不也是可以创建属性和方法!这里是有区别的,既然不一样就有存在的价值!

    我们可以通过给原型添加属性和方法来给给对象添加属性或方法!

    Hero.prototype.name;

    Hero.prototype.sayMe = function(){"添加对象的方法其实就是添加函数"}

    让我们再深一步:当我们给对象添加了同名的属性或方法时会发生什么?


我们验证了这个例子得到得到了一些结论:

当函数对象本身的属性或方法与原型的属性或方法同名的时候:

    1、默认调用的是函数对象本身的属性或方法.

    2、通过原型增加的属性或方法的确是存在的.

    3、函数对象本身的属性或方法的优先级要高于原型的属性或方法.

二.

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容