javascript原型prototype理解

Posted 丰城人

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了javascript原型prototype理解相关的知识,希望对你有一定的参考价值。

首先我们必须明白js有几种数据类型?

String Number Boolean Object Null Undefined

object 对象下可以派生出许多其他对象

如 function  Date  Math Array等等

 

我自己简单粗暴地绘制了一张图:

红色代表对象  黑色表示prototype对象  

下面你只需记住以下几点就可以

1,拥有prototype的对象有哪些?Function  Array String Math Object function等一些内置的对象

var Student={
name:\'学生\',
grade:\'三班\',

}
var b=new Object();
console.log(b.prototype);//undefined
var c=\'aaa\';
console.log(c.prototype);//undefined
console.log(String.prototype);//字符串常见方法 如indexOf

 

为什么是未定义 因为她们是那些对象的实例化 从一个对象中实例化出来的对象是没有原型对象的

所以不能通过实例化的对象来.prototype

 

2,__proto__是每个对象都拥有属性,包括实例化的对象,作用在于 “溯源” 即查找这个对象是由哪个对象派生出来的

console.log(c.prototype);//undefined
console.log(c.__proto__);//String

 

 

练习

function show(){
alert(\'hello\');
}
console.log(show.prototype);//object
console.log(show.prototype.constructor);//function show(){alert(\'hello\');}
console.log(show.__proto__);//function(){}
console.log(show.__proto__.__proto__);//Object{}
console.log(show.__proto__.__proto__.__proto__);//null
Array.prototype.show=function(){
alert(\'hello\');
}
var arr=[1,2,3];
arr.show();//实例化一个数组也有show方法

 

以上是关于javascript原型prototype理解的主要内容,如果未能解决你的问题,请参考以下文章

深入理解javascript原型和闭包——prototype原型

javascript原型prototype理解

理解Javascript的原型链

JavaScript面向对象深入理解原型

javascript中的this与prototype,原型理解

javascript-js 的prototype原型理解讲解