iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > html >怎么理解Javascript中原型属性
  • 920
分享到

怎么理解Javascript中原型属性

2024-04-02 19:04:59 920人浏览 独家记忆
摘要

这篇文章主要介绍“怎么理解javascript中原型属性”,在日常操作中,相信很多人在怎么理解Javascript中原型属性问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么

这篇文章主要介绍“怎么理解javascript中原型属性”,在日常操作中,相信很多人在怎么理解Javascript中原型属性问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么理解Javascript中原型属性”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

  1、 理解指针

  要理解JAVASCRIPT中的原型,先理解指针,在C/C++中,会提到指针,其实,指针不应该属于C/c++的专利,上篇文章中,提到的引用类型(也是很多面向对象语言中的数据类型的叫法),就是指针。

  C/C++中对指针的解释:指针就是地址。地址为何物?

  地址:是计算机对内存每个存储单元的管理方式。在计算机的内存中,存储着若干数据,计算机的CPU是如何读取内存中的数据的?

  计算机的每个存储单元都有一个编号,就像到超市存包时,每个存包的格子都有一个编号,这个编号就是地址,内存的地址。超市每个格子为什么要有编号,目的就是为了方便服务员进行查找(根据编号进行查找),计算机每个存储单元为什么会有一个编号,目的也是为了CPU查找内存。

01

  如果某个内存中直接存储的是数据,则这种数据是基本类型的数据,如果某个内存中存储的是其它内存的编号(数据),那么这种数据就叫引用类型的数据。

  2、 理解原型

  a) 原型(属性)的概念

  JAVASCRIPT中的函数也是对象(如果不懂函数也是个对象,请百度JAVASCRIPT中函数是功能完整的类),每个函数都有一个原型(prototype)属性,这个属性是指针类型。原型属性是对象类型,所以,也可以叫原型对象,原型就是模子,模型。函数何来原型,其实理解原型(模型)更应该用构造函数来理解会更好。

  构造函数是用来构造实例的,每次用new运算符调用构造函数产生一个实例时,模型就会起作用。就像我们要造一个塑料制品(如:杯子,电脑显示器的外壳,打印机的外壳等),都有一个模具,只要是同一个模具做出来的物体,都非常相似。所以,百度上对模具的解释:模具的俗称。常用于比喻具有大量相似点的两个或多个人或者事物。

  b) 原型模式创建对象(把构造函数和原型模式合在一起)

  用同一个构造函数构造的实例,具有很多的共同点(共同的属性或者函数),这些共同点就是很多书籍描述的“所有实例共享的属性和方法”。这些共同点就是用prototype属性进行维护的。具体的做法就是:所有实例共享的属性和方法用prototype属性进行表示。

  如:

  function Person(id,name,sex){

  //在构造函数里写的是每个实例特有的属性(属性值不一样)

  this.id =id;

  this.name = name;

  this.sex = sex;

  }

  //所有人的国籍都是中国,国籍属性就用prototype来表示

  Person.prototype.country = “中国”;

  //所有人吃的逻辑都一样。所以,吃的函数也用prototype来表示

  Person.Prototype.eat = function(str){

  alert(this.name+”在吃”+str+”,天在看……”);

  }

  var p1 = new Person(“007”, “乐乐”, “女”);

  var p2 = new Person(“008”, “宝宝”, “男”);

  Console.log(p1.country);//中国

  Console.log(p2.country); //中国

  p1和p2两个实例的country属性值都是中国,因为它们两个是一个构造函数实例化出来的(一个模子“刻”出来的)。

  如下是示意图,其中带箭头的线表示指向。

02

  图中可以看出:

  1)、在Person构造函数的prototype属性中有个constructor属性,指向了构造函数本身。constructor属性到底有何用,大家先把它save到大脑中,后面给大家讲解。

  2)、两个实例p1和p2指向了Person构造函数的prototype属性,跟Person构造函数没有直接关系。

  3)、两个实例p1和p2都有[[prototype]]属性。实例靠着 [[prototype]]属性找到它所对应构造函数的原型,也是靠它来找到,原型中的属性的。注意, [[prototype]]属性不能直接在代码中使用。

  c) 原型(类型的)属性和实例(类型的)属性

  每个实例特有的属性和方法存放在实例所在内存区域,也叫实例属性,如以上例中的id,name,sex属性。所有实例共享的属性和方法,都在原型(prototype)对应的内存区域,也叫原型的属性,如上例中的country。

  i. 原型(类型的)属性变成实例(类型的)属性

  这里有点疑惑,随着时间的推移,有的对象的原型属性的值会发生变化?

  如:宝宝年轻时,觉得俄罗斯的美女多,决定定居俄罗斯了。即p2的country(国籍)的值为俄罗斯。那该如何是好,改还是不改?改了会不会影响其它对象的country属性的值。不改,又不能满足需求。看来,JAVASCRIPT在这方面还是考虑到了。可以改,而且不会影响其它对象的属性值。

  还有,如果出现了实例属性和原型属性重名的情况,用实例来访问该属性时,到底访问的是实例属性还是原型属性。这个JAVASCRIPT中解决了。

  如何解决上面的问题的。在JAVASCRIPT中,当给原型属性赋值时,在对应实例中会增加了一个同名的实例属性,然后把值赋给实例属性,而原型属性的值不受影响。当访问该属性时,先在实例属性中寻找,如果找不到,再在原型属性中找。

  如以下代码:

  P2.country = “俄罗斯”;

  执行时,内存会变成如下:

03

  在p2的实例中增加一个country实例属性,内容为“俄罗斯”(图中红色的框里)。这样,代码p1.country依然去找实例属性的值“中国”。而p2.country先在实例属性中找country,找到了,就不用去原型属性中去找了。即,当实例访问属性时,会先在实例的内存中去寻找,如果找不到就会到原型的内存中去寻找。

  ii. 删除实例(类型的)属性

  随着宝宝年龄的增长,对美女没有了兴趣,而且觉得还是在自己的国家好,又想回来。即p2.country的值为”中国”,这时候是可以利用原型里的属性值,怎么办?没事,使用delete p2.country就会把p2的实例属性country删除掉。

  放心吧,delete是不能删除掉原型的属性的。

  3、 继承时原型的理解(原型链)

  原型链是ECMAScript中实现继承的一种方式。如果不懂继承,请先百度,理解继承的概念。

  原型继承的基本思想是让原型属性(对象)指向另外一个类型的的实例。

  如:

  父对象:人

  function Person(id,name,age){

  this.id = id;

  this.name = name;

  this.age = age;

  }

  Person.prototype.eat = function(str){

  alert(this.name+"在吃"+str);

  }

  子对象:程序员

  function Programmer(languages){

  this.languages = languages;

  }

  //此句话使用原型实现了继承,子对象Programmer的原型属性指向了父对象Person的实例。

  Programmer.prototype = new Person(“008”, “宝宝”, “20”);

  Programmer.prototype.writeCode=function(){

  alert(this.name+"一边努力地写着代码,一边想着‘多写代码,多挣钱’");

  }

  从图中可以看出,子对象Programmer拥有了父对象的属性(id,name,age)和方法(eat)。自己特有的属性languages和方法writeCode()。成功完成了继承。

  特别要注意,子对象完成了继承关系后,再给子对象的原型中增加属性和方法。即,先写代码Programmer.prototype = new Person(“008”, “宝宝”, “20”); 再写代码:

  Programmer.prototype.writeCode=function(){

  alert(this.name+"一边努力地写着代码,一边想着‘多写代码,多挣钱’");

  }

  否则,当子对象的prototype(原型)属性的指向发生变化后,原来在prototype(原型)属性中所写属性和方法就会丢失。

  原型链继承:当B对象的原型属性指向了A对象的实例,而C对象的原型属性指向B对象的实例时,就完成了原型链继承。

到此,关于“怎么理解Javascript中原型属性”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

--结束END--

本文标题: 怎么理解Javascript中原型属性

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 怎么理解Javascript中原型属性
    这篇文章主要介绍“怎么理解Javascript中原型属性”,在日常操作中,相信很多人在怎么理解Javascript中原型属性问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么...
    99+
    2024-04-02
  • JavaScript中的原型和原型链怎么理解
    这篇文章主要介绍“JavaScript中的原型和原型链怎么理解”,在日常操作中,相信很多人在JavaScript中的原型和原型链怎么理解问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大...
    99+
    2024-04-02
  • JavaScript原型链怎么理解
    本篇内容介绍了“JavaScript原型链怎么理解”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.原型的关系在JavaScript中的每个...
    99+
    2023-06-21
  • JavaScript原型、原型链和constructor属性实例分析
    本文小编为大家详细介绍“JavaScript原型、原型链和constructor属性实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“JavaScript原型、原型链和constructor属性实例分...
    99+
    2024-04-02
  • 如何理解JavaScript中的原型与原型链
    本篇文章给大家分享的是有关如何理解JavaScript中的原型与原型链,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。原型和原型链关系贯穿Jav...
    99+
    2024-04-02
  • 带你理解JavaScript 原型原型链
    目录一、原型、原型链相等关系理解二:原型、原型链的意思何在 看完这篇文章,你会发现,原型、原型链原来如此简单!  上面经典的原型链相等图,根据下文的学习,你会轻易掌握。 一...
    99+
    2024-04-02
  • javascript中怎么获取属性
    这篇文章主要介绍javascript中怎么获取属性,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完! javascript获取属性的方法:1、创建一个对象的构...
    99+
    2024-04-02
  • JavaScript中延迟加载属性的原理和用法
    本篇内容介绍了“JavaScript中延迟加载属性的原理和用法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成...
    99+
    2024-04-02
  • JavaScript 对象的迷宫:深入了解属性、方法和原型
    属性 属性是对象的键值对,其中键是字符串,而值可以是任何 JavaScript 类型,包括其他对象、数组和函数。属性可以用于存储和检索数据,并且可以通过点运算符(.)或方括号运算符([])访问。例如: const person = { ...
    99+
    2024-03-13
    JavaScript 对象是构成 JavaScript 语言结构基石的动态实体 它们通过属性、方法和原型交互 提供了一种灵活且强大的数据组织和操作方式。
  • 彻底理解JavaScript的原型与原型链
    目录前言基础铺垫prototypecontructor属性__proto__原型链提高总结后语前言 原型与原型链知识历来都是面试中考察的重点,说难不算太难,但要完全理解还是得下一定...
    99+
    2024-04-02
  • Javascript中怎么实现原型和原型链
    今天就跟大家聊聊有关Javascript中怎么实现原型和原型链,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。原型Javascript中有一句话,叫一...
    99+
    2024-04-02
  • 详解JavaScript中的原型和原型链
    目录原型链图原型必备知识prototype属性(显示原型)proto属性(隐式原型)constructor属性总结 原型链图 原型必备知识 要了解原型就必须搞清三个属性:__pro...
    99+
    2024-04-02
  • javascript中title属性怎么使用
    本篇内容介绍了“javascript中title属性怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!...
    99+
    2024-04-02
  • JavaScript中怎么操作float属性
    今天就跟大家聊聊有关JavaScript中怎么操作float属性,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。JS操作css的float属性的特殊写...
    99+
    2024-04-02
  • 怎么在javascript中移除属性
    这期内容当中小编将会给大家带来有关怎么在javascript中移除属性,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。在javascript中,可以利用removeAttribute() 方法来删除属性。r...
    99+
    2023-06-14
  • Javascript中Event属性搜集整理
    altKey, button, cancelBubble, clientX, clientY, ctrlKey, fromElement, keyCode, offsetX, off...
    99+
    2022-11-15
    Javascript Event属性
  • JavaScript中原型和原型链是什么
    本篇文章给大家分享的是有关JavaScript中原型和原型链是什么,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。而原型、原型链就是其中之一。每...
    99+
    2024-04-02
  • JavaScript中怎么获取元素属性
    今天就跟大家聊聊有关JavaScript中怎么获取元素属性,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先我们需要把它们归类下:innerHTML...
    99+
    2024-04-02
  • 怎么理解JS原型、原型链、对象
    本篇内容主要讲解“怎么理解JS原型、原型链、对象”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么理解JS原型、原型链、对象”吧! 一. 普通对象与函...
    99+
    2024-04-02
  • JavaScript中怎么实现属性赋值
    这篇文章给大家介绍JavaScript中怎么实现属性赋值,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。原型链每个对象都有一个包含了一个或者多个对象的原型链,该对象正是这个原型链的起始对...
    99+
    2024-04-02
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作