浅谈js原型和原型链接_js原型链阮一峰

浅谈js原型和原型链接_js原型链阮一峰一、简述对于javascript对象(函数)原型和原型链的理解,其实不那么难,简单来说,需要理解什么是原型,怎么访问原型,什么是原型链,怎么通过原型链去访问原型,就可以大概理清楚原型和原型链的基础知识。二、浅析1、何为原型在js引擎启动的时候,其内核就生成了最基本的Object和Function的原型内容,也就是最原始最自然的代码。(1)Object的原型是一个对象变量,该对象变量存…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

一、简述

对于javascript 对象(函数) 原型和原型链的理解,其实不那么难,简单来说,需要理解什么是原型,怎么访问原型,什么是原型链,怎么通过原型链去访问原型,就可以大概理清楚原型和原型链的基础知识。

二、浅谈

1、何为原型

在js引擎启动的时候,其内核就生成了最基本的Object和Function的原型内容,也就是最原始最自然的代码。
(1)Object的原型是一个对象变量,该对象变量存储constructor、hasOwnProperty等属性;
在这里插入图片描述
(2)Function的原型为自然的代码片段,即 f(){[native code]};
在这里插入图片描述

2、如何访问原型

举个例子: 一个已声明的函数fun、Object、Function它们都可以访问到自己的原型内容,如下表格所示:

对象(函数) 访问原型方法 原型内容
fun fun.prototype {constructor: {…},_proto_: {…}}
Object Object.prototype {constructor:{},hasOwnProperty: f,…}
Function Function.prototype f(){[native code]}

3、实例(new操作之后)如何访问原型

举个例子: 实例化的函数f1和对象o1,通过下面的表格来说明如何访问它们的原型内容:

实例 访问原型方法 原型内容
f1 f1.__proto__ {constructor: {…},__proto__}
o1 o1.__proto__ {constructor: {…},hasOwnProperty:f,…}

4、何为原型链

(1)最简单的理解:将实例、函数(对象)和原型之间关系起来就叫原型链。
(2)详细一点的理解:实例通过__proto__属性访问原型,函数和对象通过prototype属性访问原型,函数原型的__proto__又可以访问对象的原型等等,他们之间形成一个关系链,就是原型链。

其他的就需要读者自己去看下面经典图,该图详细清晰的描述实例、对象和其原型间的关系,笔者建议读者在理解下图的时候结合控制台打印的结果进行分析,就可以大概了解js的原型和原型链了。
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/223097.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 车牌检测STN:Spatial Transformer Networks

    车牌检测STN:Spatial Transformer Networks参考文献:MaxJaderberg,KarenSimonyan,AndrewZisserman,KorayKavukcuoglu.SpatialTransformerNetworks,2016.linkSpatialTransformerNetworks空间变换网络MaxJaderberg,KarenSimonyan,AndrewZisserman,Kor…

    2022年10月19日
    2
  • 解决DEDECMS Call to undefined function dede_htmlspecialchars()

    解决DEDECMS Call to undefined function dede_htmlspecialchars()

    2021年9月20日
    41
  • arduino超声波测距_stm32超声波测距lcd显示

    arduino超声波测距_stm32超声波测距lcd显示加入高工智能汽车行业群(自动驾驶行业4群,车联网智能座舱3群,智能商用车行业群),加微信:15818636852,并出示名片,仅限智能网联汽车零部件及OEM厂商。目前为止,特斯拉的Autopilot一共经历了三代硬件的更迭,分别是Autopilot1.0,2.0和2.5。按照目前特斯拉的公开信息,Autopilot3.0硬件将可能在今年底和自主研发的芯片一起推出。此前,《高工智能汽车》陆…

    2025年8月30日
    5
  • layoutparser_你知道什么什么吗

    layoutparser_你知道什么什么吗从概念讲起LayoutParams,顾名思义,就是布局参数。而且大多数人对此都是司空见惯,我们XML文件里面的每一个View都会接触到layout_xxx这样的属性,这实际上就是对布局参数的描述。大概大家也就清楚了,layout_这样开头的东西都不属于View,而是控制具体显示在哪里。LayoutParams都有哪些初始化方法通常来说,我们都会把我们的控件放在XML文件…

    2022年9月15日
    3
  • 局部静态变量的定义_C语言强制转换数据类型

    局部静态变量的定义_C语言强制转换数据类型C语言中定义的静态变量存放在栈区,动态分配的内存空间位于堆区。这题答案为F为大家科普一下知识C语言中局部变量存在栈里,全局变量存静态存储区。局部变量在栈空间上分配,这个局部变量所在的函数被多次调用时,每次调用这个局部变量在栈上的位置都不一定相同。局部变量也可以在堆上动态分配,但是记得使用完这个堆空间后要释放之。全局变量全部存放在静态存储区,在程序开始执行时给全局变量分配存储区,程序行完毕就释放。在程序执行过程中它们占据固定的存储单元,而不动态地进行分配和释放;…

    2025年6月21日
    3
  • UINT32 UINT8 C 语言数据格式[通俗易懂]

    UINT32 UINT8 C 语言数据格式[通俗易懂]UINT32:32BIT无符号型整数unsignedintUINT8:8BIT无符号型整数也就是unsignedchar

    2022年9月6日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号