您的位置:首页 > Web前端 > JavaScript

js基础 ------ 原型和原型链

2017-01-19 14:59 134 查看

原型是js中的一个重要知识点,之前一直都原型一知半解,最近在做js的基础梳理,感觉很有必要做一下关于原型和原型链的总结。

 

一、普通对象和函数对象

了解原型,所有我们需要知道js中变量归根到底是啥,可能大家都听说过:万物皆对象。但对象也会有一定区分,存在 普通对象 和 函数对象, 区分规则:通过 new Function()创建的都是函数对象,其他为普通对象:

var o1 = {}, o2 = new Object(); // typeof 都是object

var f1 = function(){}, f2 = new Function('s'); // typeof 都是function

 

二、原型对象

定义一个函数对象时都会包含一些预定义的原型:prototype。

普通对象不存在prototype属性,但有一个不对外公开的_proto_属性。

function f1() {};  

console.log(f1.prototype); // f1{} 

从这可以看出,f1.prototype 就是f1的一个实例对象;

 

三、原型链

JS 在创建函数对象的时候都有一个叫做 _proto_ 的内置属性, 用于指向创建它的函数对象的原型prototype, 然后父一级别的对象有同样的会指向它上一级的prototype,依次类推,知道指向的对象未null终止。

这一些一步一步指向的对象就想链条一样,我们就把它定义成 原型链。

 

转载于:https://www.cnblogs.com/gengcjun/p/6306662.html

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: