首页 > 编程语言 >原型及原型链-JavaScript教程

原型及原型链-JavaScript教程

时间:2023-04-14 13:23:09浏览次数:38  
标签:教程 p1 proto 对象 JavaScript Person 原型 prototype 构造函数

JavaScript 是世界上最流行的脚本语言。 JavaScript 是属于 web 的语言,它适用于 PC、笔记本电脑、平板电脑和移动电话。 JavaScript 被设计为向 HTML 页面增加交互性。 许多 HTML 开发者都不是程序员,但是 JavaScript 却拥有非常简单的语法。几乎每个人都有能力将小的 JavaScript 片段添加到网页中。下面给大家分享下JavaScript教程全套视频合集:原型及原型链。

原型

原型的出现,就是为了解决 构造函数的缺点也就是给我们提供了一个给对象添加函数的方法不然构造函数只能给对象添加属性,不能合理的添加函数就太 LOW 了 prototype

每一个函数天生自带一个成员,叫做 prototype,是一个对象空间即然每一个函数都有,构造函数也是函数,构造函数也有这个对象空间这个 prototype 对象空间可以由函数名来访问 function Person() {}

console.log(Person.prototype) // 是一个对象

即然是个对象,那么我们就可以向里面放入一些东西 function Person() {}

Person.prototype.name = 'prototype'

Person.prototype.sayHi = function () {}

我们发现了一个叫做 prototype 的空间是和函数有关联的并且可以向里面存储一些东西重点: 在函数的 prototype 里面存储的内容,不是给函数使用的,是给函数的每一个实例化对象使用的那实例化对象怎么使用能? proto

每一个对象都天生自带一个成员,叫做 proto,是一个对象空间即然每一个对象都有,实例化对象也是对象,那么每一个实例化对象也有这个成员这个 proto 对象空间是给每一个对象使用的当你访问一个对象中的成员的时候 如果这个对象自己本身有这个成员,那么就会直接给你结果如果没有,就会去 proto 这个对象空间里面找,里面有的话就给你结果未完待续。。。 那么这个 proto 又指向哪里呢? 这个对象是由哪个构造函数 new 出来的那么这个对象的 proto 就指向这个构造函数的 prototype function Person() {}

var p1 = new Person()

console.log(p1.proto === Person.prototype) // true

我们发现实例化对象的 proto 和所属的构造函数的 prototype 是一个对象空间我们可以通过构造函数名称来向 prototype 中添加成员对象在访问的时候自己没有,可以自动去自己的 proto 中查找那么,我们之前构造函数的缺点就可以解决了 我们可以把函数放在构造函数的 prototype 中实例化对象访问的时候,自己没有,就会自动去 proto 中找那么也可以使用了 function Person() {}

Person.prototype.sayHi = function () {

console.log('hello Person')

}

var p1 = new Person()

p1.sayHi()

p1 自己没有 sayHi 方法,就会去自己的 proto 中查找p1.proto 就是 Person.prototype我们又向 Person.prototype 中添加了 sayHi 方法所以 p1.sayHi 就可以执行了 到这里,当我们实例化多个对象的时候,每个对象里面都没有方法 都是去所属的构造函数的 protottype 中查找那么每一个对象使用的函数,其实都是同一个函数那么就解决了我们构造函数的缺点 function Person() {}

Person.prototype.sayHi = function () {

console.log('hello')

}

var p1 = new Person()

var p2 = new Person()

console.log(p1.sayHi === p2.sayHi)

p1 是 Person 的一个实例p2 是 Person 的一个实例也就是说 p1.proto 和 p2.proto 指向的都是 Person.prototype当 p1 去调用 sayHi 方法的时候是去 Person.prototype 中找当 p2 去调用 sayHi 方法的时候是去 Person.prototype 中找那么两个实例化对象就是找到的一个方法,也是执行的一个方法 结论 当我们写构造函数的时候属性我们直接写在构造函数体内方法我们写在原型上 插个小消息,也方便想学习入行成为程序员的同学,在文章下方留言即可试听课程外加领取千锋HTML5、UI交互设计、PHP、Java+云数据、大数据开发、VR/AR/Unity游戏开发、Python人工智能、Linux云计算、全栈软件测试、网络安全等全部的视频学习教程。

原型链

我们刚才聊过构造函数了,也聊了原型那么问题出现了,我们说构造函数的 prototype 是一个对象又说了每一个对象都天生自带一个 proto 属性那么 构造函数的 prototype 里面的 proto 属性又指向哪里呢? 一个对象所属的构造函数

每一个对象都有一个自己所属的构造函数比如: 数组 // 数组本身也是一个对象

var arr = []

var arr2 = new Array()

以上两种方式都是创造一个数组我们就说数组所属的构造函数就是 Array 比如: 函数 // 函数本身也是一个对象

var fn = function () {}

var fun = new Function()

以上两种方式都是创造一个函数我们就说函数所属的构造函数就是 Function constructor

对象的 proto 里面也有一个成员叫做 constructor这个属性就是指向当前这个对象所属的构造函数 链状结构

当一个对象我们不知道准确的是谁构造的时候,我们呢就把它看成 Object 的实例化对象也就是说,我们的 构造函数 的 prototype 的 proto 指向的是 Object.prototype那么 Object.prototype 也是个对象,那么它的 proto 又指向谁呢?因为 Object 的 js 中的顶级构造函数,我们有一句话叫 万物皆对象所以 Object.prototype 就到顶了,Object.prototype 的 proto 就是 null 原型链的访问原则

我们之前说过,访问一个对象的成员的时候,自己没有就会去 proto 中找接下来就是,如果 proto 里面没有就再去 proto 里面找一直找到 Object.prototype 里面都没有,那么就会返回 undefiend 对象的赋值

到这里,我们就会觉得,如果是赋值的话,那么也会按照原型链的规则来但是: 并不是!并不是!并不是! 重要的事情说三遍赋值的时候,就是直接给对象自己本身赋值 如果原先有就是修改原先没有就是添加不会和 proto 有关系

总结

到了这里,我们就发现了面向对象的思想模式了 当我想完成一个功能的时候先看看内置构造函数有没有能给我提供一个完成功能对象的能力如果没有,我们就自己写一个构造函数,能创造出一个完成功能的对象然后在用我们写的构造函数 new 一个对象出来,帮助我们完成功能就行了 比如: tab选项卡 我们要一个对象对象包含一个属性:是每一个点击的按钮对象包含一个属性:是每一个切换的盒子对象包含一个方法:是点击按钮能切换盒子的能力那么我们就需要自己写一个构造函数,要求 new 出来的对象有这些内容就好了然后在用构造函数 new 一个对象就行了。

标签:教程,p1,proto,对象,JavaScript,Person,原型,prototype,构造函数
From: https://www.cnblogs.com/qian-fen/p/17317998.html

相关文章

  • Unigraphics NX(UG NX)1957 安装包下载及(UG NX)1957 安装教程
    UG(UnigraphicsNX)是SiemensPLMSoftware公司出品的一个产品工程解决方案,它为用户的产品设计及加工过程提供了数字化造型和验证手段。UnigraphicsNX针对用户的虚拟产品设计和工艺设计的需求,以及满足各种工业化需求,提供了经过实践验证的解决方案。UG同时也是用户指南(userguide)和普......
  • Unigraphics NX(UG NX)1926 安装包下载及(UG NX)1926 安装教程
    UG(UnigraphicsNX)是SiemensPLMSoftware公司出品的一个产品工程解决方案,它为用户的产品设计及加工过程提供了数字化造型和验证手段。UnigraphicsNX针对用户的虚拟产品设计和工艺设计的需求,以及满足各种工业化需求,提供了经过实践验证的解决方案。UG同时也是用户指南(userguide)和普......
  • Unigraphics NX(UG NX)1899 安装包下载及(UG NX)1899 安装教程
    UG(UnigraphicsNX)是SiemensPLMSoftware公司出品的一个产品工程解决方案,它为用户的产品设计及加工过程提供了数字化造型和验证手段。UnigraphicsNX针对用户的虚拟产品设计和工艺设计的需求,以及满足各种工业化需求,提供了经过实践验证的解决方案。UG同时也是用户指南(userguide)和普......
  • 基于imx8m plus开发板全体系开发教程4:Linux系统开发
    前言:i.MX8MPlus开发板是一款拥有4个Cortex-A53核心,运行频率1.8GHz;1个Cortex-M7核心,运行频率800MHz;此外还集成了一个2.3TOPS的NPU,大大加速机器学习推理。全文所使用的开发平台均为与NXP官方合作的FS-IMX8MPCA开发板(华清远见imx8mp开发板),支持Weston、ubuntu20.04、A......
  • 信创操作系统--麒麟Kylin桌面版(项目一 操作系统安装教程3:麒麟系统驱动安装)
    安装驱动1.1安装显卡驱动1.1.1AMD显卡驱动安装在麒麟操作系统中,其内核已集成AMD显卡的开源驱动,该开源驱动体验良好,能满足日常办公的使用。若要在麒麟操作系统中使用图形密集型程序(如玩游戏、绘制CAD、视频剪辑等),建议安装mesa-vulkan-drivers驱动程序包。在终端中执行以下命令,安装......
  • 【manim动画教程】--高级动画效果
    在常用的动画效果中,介绍了一些元素的创建,销毁,移动和变换的方法,这些方法都是针对单个动画的。如果需要多个动画互相关联,或者元素需要有更复杂的运动方式,那么,仅仅依靠常用的动画效果可能就无法满足要求了。本篇的高级动画效果主要介绍一些更加灵活的元素运动方式,如何组合多个动画,......
  • JavaScript 之 confirm,alert,prompt
    //confirmfunctiondisp_confirm(){varr=confirm("Pressabutton!")if(r==true){alert("YoupressedOK!")}else{alert("YoupressedCancel!")}}//alert<script>window.alert("确......
  • Vue2入门之超详细教程六-数据代理
    1、简介这章有点长,希望大家可以耐心看完。在了解数据代理之前需要先了解Object.defineProperty,Object.defineProperty就是给一个对象添加属性用的。数据代理,通过一个对象代理对另一个对象中数据的操作(读/写)。Vue中的数据代理:通过vm对象来代理data对象中的数下......
  • JavaScript 之 JSON [1]介绍、语法、值
    JavaScript之JSON[1]介绍、语法、值1、简介JSON指的是JavaScript对象表示法(JavaScriptObjectNotation)JSON是轻量级的文本数据交换格式JSON使用Javascript语法来描述数据对象,但JSON仍独立于语言和平台。JSON解析器和JSON库支持许多不同的编程语言。目前非常......
  • 版本管理工具Git:入门教程
    Git使用教程目录Git使用教程1.简介2.安装与配置安装配置3.Git的区域概念4.从远程创建一个新仓库①创建一个远程仓库②把远程仓库取到本地③尝试自己写个提交④再来个提交⑤把提交推送到远程仓库5.本地创建仓库并关联到远程仓库①在项目目录中新建一个仓库②创建一个空白的远程仓......