返回顶部
首页 > 资讯 > 精选 >JavaScript原型及实例分析
  • 956
分享到

JavaScript原型及实例分析

2023-06-22 05:06:54 956人浏览 独家记忆
摘要

今天就跟大家聊聊有关javascript原型及实例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。构造函数 实例 原型三者的关系任何函数都有一个prototype属性,该属性是一个

今天就跟大家聊聊有关javascript原型及实例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。

构造函数 实例 原型三者的关系

任何函数都有一个prototype属性,该属性是一个对象

function F () {}console.log(F.prototype) // => object//原型对象F.prototype.sayHi = function () {  console.log('hi!')}

构造函数的prototype对象默认都有一个constructor属性,指向prototype对象所在函数

console.log(F.constructor === F) // => true//表示这个

通过构造函数得到的实例对象内部会包含一个指向构造函数的prototype对象的指针_proto_

var instance = new F()console.log(instance.__proto__ === F.prototype) // => true

意思是用当前构造函数创建的实例对象内部都包含一个指针,这个指针就是_proto_,然后这个指针是指向构造函数的prototype对象的

因此我们可以直接用实例访问原型对象上的成员

例:

instance.sayHi() // => 打印hi!

注意

_proto_是一个非标准属性

prototype属性

Javascript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象。
这个对象的所有属性和方法,都会被构造函数的实例继承。

这也就意味着,我们可以把所有对象实例需要共享的属性和方法直接定义在prototype对象上。

例子:

function Person (name, age) {  this.name = name  this.age = age}console.log(Person.prototype)//打印原型Person.prototype.type = 'human'//将human挂载到原型对象的属性上Person.prototype.sayName = function () {//还可以定义函数  console.log(this.name)}let p1 = new Person(...)let p2 = new Person(...)console.log(p1.sayName === p2.sayName) // => true

我们可以看到console.log(p1.sayName === p2.sayName)这行代码打印的结果是true

这是因为所有实例的type属性和sayName()方法都是一个同一个内存地址,都是指向prototype对象,因此提高了运行效率

属性或成员的搜索原则

我们知道了多个实例对象是可以共享原型对象中的属性或成员的,那么js中是怎么实现这个共享机制的呢?

这就不得不提到属性的搜索原则了

每当代码读取某个实例对象的某个属性时,都会执行一次搜索,搜索目标是具有给定名字的属性或者成员

搜索过程如下:

首先从对象实例本身开始搜索

如果在实例对象中找到了具有给定名字的属性,则返回该属性的值

如果没有找到,则继续搜索实例对象中含有的指针(上文中讲过)指向的原型对象,在原型对象中查找具有给定名字的属性

如果在原型对象中找到了这个属性,则返回该属性的值

在执行instance.sayName()时,会执行两次搜索,第一次搜索实例对象,第二次搜索原型对象

看完上述内容,你们对JavaScript原型及实例分析有进一步的了解吗?如果还想了解更多知识或者相关内容,请关注编程网精选频道,感谢大家的支持。

--结束END--

本文标题: JavaScript原型及实例分析

本文链接: https://lsjlt.com/news/302818.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript原型及实例分析
    今天就跟大家聊聊有关JavaScript原型及实例分析,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。构造函数 实例 原型三者的关系任何函数都有一个prototype属性,该属性是一个...
    99+
    2023-06-22
  • JavaScript原型实例分析
    这篇文章主要讲解了“JavaScript原型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原型实例分析”吧!先看三个对象一、构造函数(对象):JS中声明函数的三种...
    99+
    2023-06-29
  • JavaScript原型与继承实例分析
    今天小编给大家分享一下JavaScript原型与继承实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。首先我们需要知道的...
    99+
    2023-06-27
  • JavaScript原型、原型链和constructor属性实例分析
    本文小编为大家详细介绍“JavaScript原型、原型链和constructor属性实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript原型、原型链和constructor属性实例分...
    99+
    2024-04-02
  • JavaScript的原型对象与原型链实例分析
    本篇内容介绍了“JavaScript的原型对象与原型链实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!一、prototype和__pr...
    99+
    2023-07-02
  • JavaScript原始包装类型实例分析
    这篇文章主要讲解了“JavaScript原始包装类型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原始包装类型实例分析”吧!引出问题: 如下一段简单的代...
    99+
    2023-06-30
  • javascript中原型与原型链的示例分析
    这篇文章主要为大家展示了“javascript中原型与原型链的示例分析”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“javascript中原型与原型链的示例分析...
    99+
    2024-04-02
  • JavaScript中从原型到原型链的示例分析
    这篇“JavaScript中从原型到原型链的示例分析”除了程序员外大部分人都不太理解,今天小编为了让大家更加理解“JavaScript中从原型到原型链的示例分析”,给大家总结了以下内容,具有一定借鉴价值,内容详细步骤清晰,细节处理妥当,希望...
    99+
    2023-06-14
  • JavaScript原型继承的示例分析
    这篇文章主要介绍JavaScript原型继承的示例分析,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!在传统的基于Class的语言如Java、C++中,继承的本质是扩展一个已有的Cla...
    99+
    2024-04-02
  • javascript构造函数以及原型对象的示例分析
    小编给大家分享一下javascript构造函数以及原型对象的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!如果是实例方法,不同的实例化,它们引用的地址是不一样的,是唯一的。//定义...
    99+
    2024-04-02
  • JavaScript构造函数和原型使用实例分析
    本文小编为大家详细介绍“JavaScript构造函数和原型使用实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript构造函数和原型使用实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1...
    99+
    2023-07-04
  • Linux函数原型实例分析
    本篇内容主要讲解“Linux函数原型实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linux函数原型实例分析”吧!引言条件变量是利用线程间共享的全局变量...
    99+
    2024-04-02
  • JavaScript原型数据共享的示例分析
    这篇文章主要介绍了JavaScript原型数据共享的示例分析,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。JavaScript的作用是什么1、能够嵌入动态文本于HTML页面。...
    99+
    2023-06-15
  • JavaScript闭包原理及作用的示例分析
    小编给大家分享一下JavaScript闭包原理及作用的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!简介说明本文介绍JavaScript的闭包的作用、用途及其原理。闭包的定义闭包是指内部函数总是可以访问其所在的外部...
    99+
    2023-06-22
  • JavaScript数据类型使用实例分析
    这篇文章主要讲解了“JavaScript数据类型使用实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript数据类型使用实例分析”吧! ...
    99+
    2024-04-02
  • Android Handler 原理分析及实例代码
    Android Handler 原理分析 Handler一个让无数android开发者头疼的东西,希望我今天这边文章能为您彻底根治这个问题 今天就为大家详细剖析下Handler...
    99+
    2022-06-06
    handler Android
  • JavaScript原型与实例详解
    目录构造函数实例原型三者的关系prototype属性属性或成员的搜索原则总结构造函数 实例 原型三者的关系 1.任何函数都有一个prototype属性,该属性是一个对象 func...
    99+
    2024-04-02
  • MySQL InnoDB锁类型及锁原理实例解析
    目录锁共享锁排他锁意向锁记录锁间隙锁临键锁死锁死锁产生条件行锁发生死锁表锁发生死锁锁的释放事务阻塞死锁的避免锁的日志行锁的原理不带任何索引的表带主键索引的表带唯一索引的表结论1.表必定有索引2.唯一索引数据行加锁,主键索...
    99+
    2022-11-27
    MySQL InnoDB锁类型锁原理 MySQL InnoDB 锁
  • JavaScript中的数据类型Number实例分析
    这篇“JavaScript中的数据类型Number实例分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JavaScript...
    99+
    2023-06-30
  • Vue3.x最小原型系统实例分析
    这篇文章主要介绍了Vue3.x最小原型系统实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Vue3.x最小原型系统实例分析文章都会有所收获,下面我们一起来看看吧。一、 项目初始化既然用Vue3.0构建最小...
    99+
    2023-06-29
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作