0

0

通俗易懂解析JS原型与原型链

php中世界最好的语言

php中世界最好的语言

发布时间:2018-06-04 11:07:12

|

2069人浏览过

|

来源于php中文网

原创

这次给大家带来通俗易懂解析js原型与原型链,解析js原型与原型链的注意事项有哪些,下面就是实战案例,一起来看一下。

Browser中的对象

浏览器中有哪些对象?ES中规定全局对象为global,而浏览器中规定全局对象为window。

在chrome控制台中输入window,我们就能看到window里有哪些内容。

下面的这些对象在window里都能找到。
如Object,Sring,Numbr,Boolean,Array,Date,Math,parseInt, parseFloat这些属性都是ES规定的必须有的对象。
如doucument,alert,prompt,atob等这些是浏览器中内置的属性。

这些对象都具有hash结构,如Object下,String下都有自己的属性和方法,都有相应的API调用。

简单类型和对象

例子如下:n1是简单类型,n2是对象。

var n1 = 'a'var n2 = new String('a')
n1.length
n1.hasOwnProperty('0')
n2.length
n2.hasOwnProperty('0')
n1.xxx = 2n1.xxx // undefined

区别

n1值是存储在stack中。n2赋值时,stack中建立一个地址,指向heap中,堆内存中新建了一个String类型的对象。能看到对象n2里有一些属性,还有prototype属性。

属性

n2是对象,里面有length属性,所以调用。n1只是字符串,为何也有length属性

可以这样理解:n1.length时,这时js会进行如下操作:var temp = new String(n1);n1.length;也就是使用属性,或方法时,会临时的在堆内存中新建一个对象,这个对象是相应的String类型,执行后,temp便被销毁。因此n1.xxx = 2操作不会报错,而再次n1.xxx显示undefined,因为此时n1在堆内存中的数据已经销毁了。

因此,js中,很少使用new一个新对象的方法,而是直接对变量进行赋值。

n2中的hasOwnProperty()

hasOwnProperty()是Object类型中的方法,Sting类型下并没有找到它,在哪找到它?

绘蛙AI修图
绘蛙AI修图

绘蛙平台AI修图工具,支持手脚修复、商品重绘、AI扩图、AI换色

下载

这里hasOwnProperty()是在n2.proto.proto里面。n2.proto指向的是String.prototype,而String.prototype.proto最后指向Object.prototype。String是一种原型,Object也是一种原型。Object.prototype中存放了所有Object类型的公共属性。

以这种方式,能有效的节省空间,避免每个对象里面都记录很多的属性,一个object里没有的属性,就到proto指向的对象里面寻找。而指向的地方通常是某个原型的prototype。

去哪里找 proto和prototype

var n = new Number(1)var s= new String('1')var o= new Object()

以上几种方式都能看成 var 对象 = 函数()的形式。
归纳出,对象.proto =函数.prototype。

访问 proto

proto是相对于对象来说,找爸爸,看是谁生成的对象。对n来说,爸爸是Number,就去Number.prototype里面寻找。Number里也有proto,访问时,到它的爸爸Object里面寻找。

Function
String.proto === Function.prototype //true

函数也能看作是对象,String,Object,Number都是对象,也都是函数。因为之前用到了new String(),所以这是函数,函数return结果的数据类型为object。String的爸爸便是Function。

Function.proto === Function.prototype //trueFunction.prototype.proto === Object.prototype //trueFunction.proto.proto === Object.prototype //true

当把函数Function看作是由Function方法生成的对象时,
即var Function = new Function()
便能理解 Function.proto === Function.prototype

Fuction的类型是function,它是由Function构造出来的。关系从上图可以看出来。new String()时,String的类型也是function,String.proto指向的就是Function.prototype。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

JS中怎样避免特性与浏览器推断

JS门面模式使用案例详解

相关专题

更多
vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

26

2025.12.30

金山文档相关教程
金山文档相关教程

本专题整合了金山文档相关教程,阅读专题下面的文章了解更多详细操作。

28

2025.12.30

PS反选快捷键
PS反选快捷键

本专题整合了ps反选快捷键介绍,阅读下面的文章找到答案。

25

2025.12.30

表格中一行两行的方法
表格中一行两行的方法

本专题整合了表格中一行两行的相关教程,阅读专题下面的文章了解更多详细内容。

3

2025.12.30

cpu温度过高解决方法大全
cpu温度过高解决方法大全

本专题整合了cpu温度过高相关教程,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

ASCII码介绍
ASCII码介绍

本专题整合了ASCII码相关内容,阅读专题下面的文章了解更多详细内容。

31

2025.12.30

GPS是什么
GPS是什么

本专题整合了GPS相关内容,阅读专题下面的文章了解更多详细内容。

3

2025.12.30

wifi拒绝接入
wifi拒绝接入

本专题整合了wifi拒绝接入相关教程,阅读下面的文章了解更多详细方法。

9

2025.12.30

丰网速运介绍
丰网速运介绍

本专题整合了丰网速运查询入口以及相关内容,阅读专题下面的文章了解更多内容。

3

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 3.1万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 1.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 2.7万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号