iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >JavaScript原型实例分析
  • 154
分享到

JavaScript原型实例分析

2023-06-29 08:06:43 154人浏览 八月长安
摘要

这篇文章主要讲解了“javascript原型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原型实例分析”吧!先看三个对象一、构造函数(对象):JS中声明函数的三种

这篇文章主要讲解了“javascript原型实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JavaScript原型实例分析”吧!

    先看三个对象

    一、构造函数(对象):

    JS中声明函数的三种方式

    function 函数名(){}声明

    匿名函数声明 var foo = function () {}

    构造函数声明 var foo = new Function("形参1","形参2","形参3")。任何函数都可以用

    new Function 来创建

            function fn1(name,age) {            console.log(`我叫${name},我今年${age}岁`);        }        fn1('小航',19)        // 定义函数的第二种方式        const fn2 = function(name,sex) {            console.log(`我叫${name},性别${sex}`);        }        fn2('小航','男')        fn3('小航','男')        // Function也是一个构造函数        // 上面的方式和下面的fn4声明函数的方式是一致的        const fn4 = new Function('name','age','console.log(`我叫${name},性别${sex}`)')        // 当然还有箭头函数 只是写法变了 和第一种类似        const fn3 = (name, sex) => {            console.log(`我叫${name},性别${sex}`);        }

    当我们用函数去创建对象时,如下Fun就是构造函数。fn()是实例对象

            function Fun() {        }        var fn = new Fun()        console.log(fn.__proto__ === Fun.prototype); // true

    并且知道:

    任何函数,上面的fn fn1 fn2 fn2都是Fun的实例,而Fun也是构造函数Function的实例,Function是js内置的对象。

    看到上面一段代码,Fun.prototype指代/指向的是原型(对象,后面直接称为原型)。

     我们接下来看第二个对象:

     二、实例对象

            function fn1(name,age) {            console.log(`我叫${name},我今年${age}岁`);        }        const obj1 = {            name: '小航',            age: '19'        }

    知道以下知识点:

    只要用new关键字 + 构造函数生成的对象,就是实例对象

    即便没有用new + 关键字,而是用比如字面量创建对象,或者是函数直接 function 函数名() {} 这样声明,生成的也是实例对象,如上面代码 。

     记住重要的知识点:所有的实例对象都有__proto__属性,甚至可以去掉实例,改为所有的对象都有__proto__属性。      

    知道如下代码中,fn 是构造函数Fun的实例对象,并且Fun也是构造函数Function的实例对象。

            function Fun() {        }        var fn = new Fun()

    得出的结论是:

    fn实例对象的__proto__属性指向构造函数Fun的属性prototype【原型】

    而Fun的实例对象的__proto__属性也指向构造函数的Function的prototype【原型】              备注:在这里,prototype既是Fun的属性,而Fun.prototype也是最终的一个地方,目的地,这个目的地叫作原型对象。

            // 1. fn是Fun()构造函数的实例 实例对象的__proto__属性都会指向自身构造函数的prototype属性        function Fun() {        }        var fn = new Fun()        console.log(fn.__proto__ === Fun.prototype); // true        // 2. Fun函数是Function构造函数的实例 因此Fun的__proto__和构造函数Function指向同一个地方        console.log(Fun.__proto__ === Function.prototype); // true

    第一个console对应下图的序号1,第二个console对应下图的序号4

    JavaScript原型实例分析

    三、 原型对象:

    知道知识点:

    所有的函数都有一个原型对象。比如函数Function,它有原型对象Function.prototype。也有说法叫Function.prototype 为 函数Function的伴生对象,意思是函数Function一创建,就有一个陪伴它一起创建的对象叫Function.prototype。而Function自己的身上,又有一个属性叫作prototype,这个属性指向了它的伴生对象。

    函数的原型对象身上有一个属性,叫作,constructor,它能够指回构造函数。就好像,构造函数Function通过属性prototype指向了原型对象Function.prototype,而原型对象Function.prototype通过自身的constructor属性指回去。

     比如下面的,可以自行验证。

            function fn() {        }        console.log(fn.prototype);        console.log(fn.prototype.constructor === fn); // true

    函数的原型对象身上还有一个属性,叫作__proto__属性。浏览器打印出来现在长这样,

    [[Prototype]]: Object

    原型当中的__proto__指向父类的原型对象prototype,比如下面的代码

    下面的意思是函数Person的prototype,这是一个原型对象,它的__proto__属性指向Object父类的prototype,Function也是类似。为什么是这样?

    因为既然Person.prototypeFunction.prototype都叫作原型对象,都是对象,那么本质都是通过new Object创建的,都是构造函数Object的实例,因此它们也是实例对象,身上也有__proto__属性指向Object父类。

        function Person() {    }    console.log(Person.prototype.__proto__ === Object.prototype); // true    console.log(Function.prototype.__proto__ === Object.prototype); // true

    对应下图的序号3

    JavaScript原型实例分析

    记住:

    Object是各个对象的根

    再看三个属性:

    一、prototype:

    记住这个属性是函数独有的

    下面的代码,fn有prototype,Fun构造函数有prototype,Function下面没写出来,但是也有prototype。

    看代码

            var fn55 = new Function('age', 'sex', 'console.log(`今年${age}性别${sex}`)')        console.log(fn55.prototype);        console.log(fn55.__proto__ === Function.prototype); // true

    注意:

    上面的fn55是通过new Function创建的一个函数,

    函数有prototype 

    同时fn55也是通过new + Function 创建的一个实例对象, 因此也有__proto__,指向Function构造函数的prototype

    看下面代码

            function Fun(name, age) {            this.name = name;            this.age = age        }           var fnn = new Fun('小航', '123')        console.log(fnn.prototype); // undefined

    注意上面代码:

    上面是通过new + Fun 创建了一个实例对象

    这里是通过构造函数Fun创建了一个对象fnn,而fnn并不是函数,因此并没有prototype原型对象

    二、__proto__

    记得万物都是对象 因此万物都有__proto__

    构造函数的创建的实例对象,有__proto__,指向构造函数的prototype

            function Person(name,age) {            this.name = name            this.age= age        }        Person.prototype.sayHello = function() {            console.log(this.name);        }        const obj1 = {            name: '小航',            age: '19'        }        const obj2 = new Object()        obj2.name = '焦迈奇'        obj2.age = '19'        console.log(obj1);        console.log(obj2);        console.log(Person.prototype);        const person1 = new Person('小红', 19)        const person2 = new Person('小明', 20)        console.log(person1.__proto__);        console.log(person2.__proto__);        console.log(Person.prototype === person1.__proto__);// true        console.log(Person.prototype === person2.__proto__);// true        console.log(Object.prototype === obj1.__proto__);   // true        console.log(Object.prototype === obj2.__proto__);        // true

    函数实例有__proto__,也指向构造函数Function

            // 2. 创建函数的几种方式        // 定义函数的第一种方式        function fn1(name,age) {            console.log(`我叫${name},我今年${age}岁`);        }        fn1('小航',19)        // 定义函数的第二种方式        const fn2 = function(name,sex) {            console.log(`我叫${name},性别${sex}`);        }        fn2('小航','男')        // 或者箭头函数        const fn3 = (name, sex) => {            console.log(`我叫${name},性别${sex}`);        }        fn3('小航','男')        // 这三个函数的__proto__等于构造函数Function的prototype        // Function也是一个构造函数        // 上面的三种方式本质和下面的fn4声明函数的方式是一致的        // 定义函数的第三种方式        const fn4 = new Function('name','age','console.log(`我叫${name},性别${sex}`)')        // console.log(Function.prototype === fn1.__proto__); // true        // console.log(Function.prototype === fn2.__proto__); // true        // console.log(Function.prototype === fn3.__proto__); // true        // console.log(Function.prototype === fn4.__proto__); // true

    function Object和 function Function 都是构造函数Function的实例,因此也有__proto__

            console.log(Object.__proto__ === Function.prototype);         // true        console.log(Function.__proto__ === Function.prototype);        // true

    原型对象也是对象,因此也有__proto__

            function Person() {        }        console.log(Person.prototype.__proto__ === Object.prototype); // true        console.log(Function.prototype.__proto__ === Object.prototype); // true

    三、constructor属性

    每一个原型对象身上,才有constructor属性

            function fn() {        }        console.log(fn.prototype);        console.log(fn.prototype.constructor === fn); // true        console.log(Function.prototype.constructor === Function); // true        console.log(Object.prototype.constructor === Object);

    一些更加复杂的情况

    console.log(obj.__proto__.constructor.__proto__.__proto__.__proto__=== null); // null

    obj.__proto__指向Object.prototype

    Object.prototype.constructor就是指向Object本身

    备注:Object也是构造函数也是Function的实例对象 因此下面Object也有__proto__

    Object.__proto__指向Function.prototype

    Function.prototype.__proto__指向什么?这个就是[原型对象也是对象]原型对象的__proto__指向什么?指向的是父类的prototype也就是Object.prototype

    Object.prototype指向什么,就是原型链的终点null 可以下去自行验证

    原型链

    原型链就是__proto__的终点

    感谢各位的阅读,以上就是“JavaScript原型实例分析”的内容了,经过本文的学习后,相信大家对JavaScript原型实例分析这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

    --结束END--

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

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

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

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

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

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

    • 微信公众号

    • 商务合作