问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

javascript 什么是原型链

发布网友 发布时间:2022-04-23 07:23

我来回答

1个回答

热心网友 时间:2022-05-14 12:43

原型链一直是个很抽象的概念,看不到,摸不着.随着最近对JavaScript进一步的学习,我对原型链有了一点理解,下面讲出来.
基础知识
在JavaScript中,一共有两种类型的值,原始值和对象值.每个对象都有一个内部属性[[prototype]],我们通常称之为原型.原型的值可以是一个对象,也可以是null.如果它的值是一个对象,则这个对象也一定有自己的原型.这样就形成了一条线性的链,我们称之为原型链.
访问一个对象的原型可以使用ES5中的Object.getPrototypeOf方法,或者ES6中的__proto__属性.
原型链的作用是用来实现继承,比如我们新建一个数组,数组的方法就是从数组的原型上继承而来的.
var arr = [];
arr.map === Array.prototype.map //arr.map是从arr.__proto__上继承下来的,arr.__proto__也就是Array.prototype

图形化原型链
虽然我们都说原型链,但实际上,在不考虑网页中frame的情况,js引擎在执行期间的某一时刻,所有存在的对象组成的是一棵原型树.默认情况下,只有一棵树.根节点可以说是Object.prototype,也可以说是null.

但我们可以再建立一棵原型树,通过使用Object.create方法
var foo = Object.create(null); //foo是一个对象,但它是游离的,不属于已有的那棵原型树
var bar = Object.create(foo); //bar的原型是foo
var baz = Object.create(foo); //baz的原型是foo

这样我们有了第二棵原型树

遍历原型链
我们没有办法遍历到所有以某个对象为原型的对象,但我们可以向上遍历,获取到一个对象所有的上层原型,这个原型链必定是线性的,尽头是null.
function getPrototypeChain(object) {
var protoChain = [];
while (object = object.__proto__) {
protoChain.push(object);
}
protoChain.push(null);
return protoChain;
}

试验一下,不同的环境实现不同,显示形式也不同.下面是在chrome控制台中的显示.
>getPrototypeChain(new String(""))
[String, Object, null] //依次是String.prototype,Object.prototype,null

>getPrototypeChain(function(){})
[function Empty() {}, Object, null] //依次是Function.prototype,Object.prototype,null

内置类型的对象的原型链并不长,下面试试宿主对象.
>getPrototypeChain(document.createElement("div"))
[HTMLDivElement, HTMLElement, Element, Node, Object, null]

这个就长多了.
超长原型链
可以看出来,我们平时使用的对象并没有很长的原型链.但可以自己构造一个.
function Foo() {}

for (var i = 0; i < 100; i++) {
Foo.prototype["foo" + i] = i;
Foo.prototype = new Foo;
}
console.dir(getPrototypeChain(new Foo));

最后的这个new Foo有多少个上层原型呢?
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
QQ空间代码不用了。怎么回原? 怎样才能把我的QQ空间变回原样啊~~~(我乱用代码的后果~555555~~) 小的的意思是什么 ...中,硫元素的化合价最高的是( )A.SO2B.H2SO4C.H2SD.Na2SO ...中硫元素化合价相同( )A.S、SO2B.SO2、H2SO4C.H2S、H2SO4D.SO3... 下列硫的单质和化合物中,硫元素的化合价是+4的是( )A.SB.SO2C.H2SD... 下列化合物中,硫元素的化合价为+4价的是( )A.H2SB.SO2C.SO3D.H2SO 下列化合物中,硫元素的化合价为+4价的是( )A.CaSO4B.H2SC.Na2SO3D... ...元素的化合价为+4价的是( )A.SO2B.H2SC.SO3D.H2SO 梦幻西游:三界功绩有什么用?原来有这么多用处 超链接后面跟的参数都是string字符窜类型吗? 要求编写一个函数string_to_list(char s[]),将s中的每一个字符存放到该链表结构中 用链表实现 如何用java双链表实现对一个string的查找,插入,删除,逆序输出 html 链接传多个String类型值 C++链表中的string成员怎么读入? 关于数据结构,链表,c语言。如何将string类型的name变量赋值给链表的data域? c++里面链表节点是包含string类型的结构体,怎么用二进制方式写入文件并读取 如何在string.XML文件添加一个链接 链表可以存string类型的数据吗?为什么? c++中的string类,就是包含在&lt;string&gt;中的,是用什么存储字符串的?字符指针?链表?还是其他? c语言中如何读取string字符串中的网页链接? word 2013 怎么删除页眉的横线 word2013如何去掉页眉上的横线 13版office,自动加上了页眉线,怎样去掉页眉的横线? word2013怎么删除页眉的横线 word2013怎样删除页眉的横线 猪肉竹笋香菇饺子怎么做 虾仁竹笋水饺馅的做法 竹笋可以和什么菜放一起做饺子馅 用java怎么链接到本地的sqlserver数据库啊 写java语句 特别是String url=多少和class.forname里面的值 标准C++中 include&lt;string&gt; 这一行导入的是代码还是静态链接库?我该如何查看string这个类的定义? vc++相关问题。 我写了一个DLL文件,然后,在DLL文件中使用了string类型,能够编译,链接成功。 为什么我用String title_num = request.getParameter(&quot;id&quot;);得不到上一jsp页面中超链接中的id呢? nova7pro外屏多少钱? nova7pro换屏价格? 华为nova七pro的换 后壳多少钱? nova7pro型号jer. an20,曲屏,这款手机质量怎么样,多少钱?哪位大神能告诉我,谢谢! 华为nova7pro性价比怎么样? 华为nova+7+pro用了一年还能卖多少钱去年七月份买的,无如何毛病,九九新_百度问一问 怎样查出三年内微信转账记录? 你好,华为Nova7 pro会降价吗? 华为nova7pro2020七月买的现在卖多少钱? nova7Pro换个后壳多少钱? 添加好友设置问题大全 有什么有趣的qq添加好友问题 加好友问题可以设置什么? 梦到在核桃树下掉了许多核桃,自己在捡核桃什么意思 梦见核桃树下成熟的核桃掉的满地都是,也不知是谁还拨开一个,里面的果... 关于QQ加好友的问题。