JavaScript中的原型与原型链详解

本文主要和大家分享javascript中的原型与原型链详解,说原型的时候,一般都是在说原型属性prototype。

一.介绍

1.函数的prototype属性

*所有的函数都有一个prototype属性,它默认指向一个object空对象(即称为原型对象)

*原型对象中有一个属性constructor,它指向函数对象

立即学习“Java免费学习笔记(深入)”;

2.原型对象有什么作用?—–>给原型对象添加属性(一般都是添加方法)

*作用:函数的所有实例对象自动拥有原型中的属性(方法)

//*所有的函数都有一个prototype属性,它默认指向一个object空对象(即称为原型对象)console.log(Date.prototype)//系统内置的,如Date函数  //输出的是object {}  里面有很多属性与方法,这些是后来增加的,function Fn () {}console.log(Fn.prototype)//这是我们自定义的函数  有constructor//*原型对象中有一个属性constructor,它指向函数对象console.log(Fn.prototype.constructor===Fn);//输出的函数 Fn.prototype.constructor是引用变量 Fn也是引用变量Fn.prototype.test=function (){console.log('test()')}Fn.prototype.test();//可以这样用,但是一般不是这样//一般都是先实例化,然后调用函数var fn=new Fn();fn.test();

登录后复制

3.显式原型与隐式原型

*所有的函数function 都有一个prototype属性,即为显式原型

*所有的实例对象都有一个__proto__,可称为隐式原型

*对象的隐式原型的值为其对应构造函数的显式原型的值

3.1 显式原型与隐式原型问题

(1).prototype属性是什么时候加上,它的值是多少?

在定义函数(函数对象被创建)时,Js 引擎自动添加的。默认值是一个空的object实例对象

(注意:定义函数时,内部执行:Fn.prototype={}  Fn.prototype.constructor===Fn)

(2).__proto__属性是什么时候加上,它的值是多少?

在创建实例对象时,Js 引擎自动添加的。值为构造函数的prototype属性值

(注意:定义函数时,内部执行:this.__proto__=Fn.prototype(是new出来的实例化对象))

3.2总结

a.函数的prototype属性:在定义函数(函数对象被创建)时,Js 引擎自动添加的,默认值是一个空object对象

b.对象的__proto__属性:创建实例对象时,Js 引擎自动添加的,默认值为构造函数的prototype属性值

c.程序员能直接操作显式原型,但不能直接操作隐式原型(es6之前)

function Fn() {//内部执行Fn.prototype={} Fn.prototype.constructor===Fn                // body...            }            //每个函数function 都有一个prototype属性,即为显式原型            console.log(Fn.prototype)            //每个实例对象都有一个__proto__,可称为隐式原型            var fn=new Fn();//内部执行:this.__proto__=Fn.prototype(是new出来的实例化对象)            console.log(fn.__proto__)            //对象的隐式原型的值为其对应构造函数的显式原型的值            console.log(Fn.prototype===fn.__proto__);//true

登录后复制

4.原型链

4.1别名,隐式原型链(因为是沿着隐式原型查找的)

4.2原型链其实是访问(或是查找)一个对象的属性时一个流程,

*先在自身属性中查找,找到返回

*如果没有,再沿着__proto__这条链向上查找,找到返回

*如果最终没找到,返回underfined

4.3作用是:查找对象的属性(方法)

JavaScript中的原型与原型链详解

分析:{}是一个new Object的实例化对象,所以就延伸到Object=0x345这边去(有一个Object的函数,就是创建Object函数对象)

4.4总结:

            *每个对象都有tostring()方法
            *fn.test3值为undefined。undefined当函数使用,会报错
            *函数对象有显示原型属性,实例化对象有隐式原型属性
            *方法尽量放在原型里面

4.5构造函数,原型,实例对象的关系

//构造函数function  Person(n){this.name = n;}//构造函数对应原型对象Person.prototype.sayHi = function(){alert("大家好,我是" + this.name);}//实例var p1 = new Person("张三");

登录后复制

a.①构造函数 和 实例之间的关系:

实例通过new 关键字调用构造函数被创造。
如:var dog1 = new Dog();

②构造函数 和 原型对象对象之间的关系:
原型对象,可以通过 构造函数名.prototype 获取到。
原型对象中的 constructor 属性会指向构造函数。
    Dog.prototype;
 JavaScript中的原型与原型链详解

③实例和原型对象之间的关系:
实例对象中的 __proto__ 属性会指向 原型对象。

JavaScript中的原型与原型链详解

b.构造函数,原型,实例对象的关系图

(1)

JavaScript中的原型与原型链详解

(2)

JavaScript中的原型与原型链详解

           console.log(Object.prototype)//Object {}           console.log(Object.__proto__)//function () {}           console.log(Object.__proto__===Date.__proto__)//true           console.log(Function.prototype===Function.__proto__)//true            console.log(Object.prototype===Object.__proto__)//false

登录后复制

总结:

*实例对象的隐式原型等于构造函数的显式原型
*任何函数都是Function 的实例,包括Function是它本身的实例化,但是不包括实例化对象(如var b=new fn(),其中b就不是Function的实例)

*通过对象.xxx查找属性时,它是引着隐式原型链(__proto__)的原型链去找,一直找到Object的原型对象的隐式原型(__proto__=null)

1.实例就是通过构造函数创建的。实例一创造出来就具有constructor属性(指向构造函数)和__proto__属性(指向原型对象),
2.构造函数中有一个prototype属性,这个属性是一个指针,指向它的原型对象。
3.原型对象内部也有一个指针(constructor属性)指向构造函数:Person.prototype.constructor = Person;
4.实例可以访问原型对象上定义的属性和方法。

5.属性问题

给对象属性赋值,是不会查找原型链的

function Person(name,age) {                this.name=name;                this.age=age;            }            Person.prototype.setName=function(name){                this.name=name;            }            Person.prototype.sex='男';            //首先来看  name,age都是自身函数有,sex是原型链上的            var p1=new Person('Tom','12');            p1.setName('jack');            console.log(p1.name,p1.age,p1.sex);//jack 12 男            p1.sex='女';//给对象属性赋值,是不会查找原型链的            console.log(p1.name,p1.age,p1.sex);//jack 12 女            var p2=new Person('Bob','21');            console.log(p2.name,p2.age,p2.sex);//jack 12 男

登录后复制

6.instanceof探索

6.1instanceof是如何判断的?

表达式:A(看着实例) instanceof B(看着构造函数)

如果B函数的显示原型对象在A对象的原型链上,返回true,否则返回false


登录后复制

            function Foo() { }            var f1=new Foo();            console.log(f1 instanceof Foo);//true            console.log(f1 instanceof Object);//true            console.log(Object instanceof Foo);//false            console.log(Object instanceof Function);//true            console.log(Object instanceof Object);//true            console.log(Function instanceof Object);//true            console.log(Function instanceof Function);//true

登录后复制

JavaScript中的原型与原型链详解

JavaScript中的原型与原型链详解

6.2Function是通过new自己产生的实例

7.题目

 /*            *查找对象属性是查找对象的原型链,查找原型链是根据隐式原型链            *隐式原型是由实例决定的            */            var A=function(){            }            A.prototype.n=1;            var b=new A();            A.prototype={//显示原型                n:2,//给显示原型重新赋值,只会影响后面创建的对象                m:3,            }            //A.prototype.m=5;            //给原型对象添加属性,对前后创建对象都有影响 console.log(b.n,b.m,c.n,c.m);//1 5 1 5            var c=new A();            console.log(b.n,b.m,c.n,c.m);//1 undefined 2 3            //题目2            var  F=function(){}            Object.prototype.a=function(){                console.log('a()')            }            Function.prototype.a=function(){                console.log('a()')            }            var f=new F();            f.a();//true            f.b();//f.b is not a function            F.a();//true            F.b();//true

登录后复制

总结:

*查找对象属性是查找对象的原型链,查找原型链是根据隐式原型链*隐式原型是由实例决定的A.prototype={//显示原型    n:2,//给显示原型重新赋值,只会影响后面创建的对象    m:3, }console.log(b.n,b.m,c.n,c.m);//1 undefined 2 3A.prototype.m=5;给原型对象添加属性,对前后创建对象都有影响 console.log(b.n,b.m,c.n,c.m);//1 5 1 5

登录后复制

相关推荐:

JavaScript原型与原型链的详细分析

以上就是JavaScript中的原型与原型链详解的详细内容,更多请关注【创想鸟】其它相关文章!

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

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2781162.html

(0)
上一篇 2025年3月8日 16:13:32
下一篇 2025年3月7日 04:29:50

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JavaScript对象详解

    一.javascript 对象介绍 1.对象是什么?对象是程序中的对象,程序是用来描述现实生活世界。 如现在要写一个程序来管理大家的信息,这边就有每个人的信息(身高,体重等),这些信息都是相互独立,如果要高效管理这些信息,就要放到一个容器(…

    编程技术 2025年3月8日
    200
  • JavaScript中数据变量内存分析

    1.什么是数据?*数据是存储于内存中代表特定信息的‘东东’,本质就是0101二进制,本文主要和大家分享javascript中数据变量内存分析,希望能帮助到大家。 eg:18  //这个18可能只年龄  或是分数等等,, 写程序中的数据都要有…

    2025年3月8日 编程技术
    200
  • JavaScript数据类型详解

    JavaScript数据类型是JavaScript中很重要的知识点,本文主要和大家分享JavaScript数据类型详解,希望能帮助到大家。 一.JavaScript 中的数据类型(重要) (1).基本数据类型(又称值类型) a.string…

    2025年3月8日
    200
  • JavaScript中函数详解

    (1).什么是函数? 具有特定功能的n条语句的封装体。只有函数是可执行的,其他类型的数据是不可执行的。函数也是对象。 (2).函数的作用 → 提高代码复用 → 便于阅读和交流 (3).函数的定义 方式一:函数声明(推荐使用)  functi…

    2025年3月8日
    200
  • JS运行机制详解

    JS运行的环境是浏览器,浏览器是多进程的,每一个Tab页面都会多开一个进程,进程中可能包括主控进程(负责浏览器的显示,用户的前进和后退等行为),GPU,浏览器内核(浏览器渲染进程,负责页面渲染,脚本执行,事件处理)等 。 其中,浏览器内核是…

    2025年3月8日
    200
  • JS原生对象和正则表达式详解

    本文主要和大家分享JS原生对象和正则表达式详解,分别有字符串对象数组对象日期对象数学对象正则表达式,希望能帮助到大家。 希望能帮助到大家。 一、字符串对象 // charAt indexOf replace search subStr //…

    编程技术 2025年3月8日
    200
  • js如何判断邮箱格式是否正确

    本文主要和大家分享js如何判断邮箱格式是否正确,本文主要以代码的形式和大家分享,希望能帮助到大家。 登录后复制 function validate_required(field,alerttxt) { with (field) { if (…

    编程技术 2025年3月8日
    200
  • 深入理解javascript中this指针

    本文主要和大家分享深入理解javascript中this指针,在写java的时候,this用错了,idea都会直接报错! 比如…… 在面向对象编程里有两个重要的概念:一个是类,一个是实例化的对象,类是一个抽象的概念,用个形象的比喻表述的话,…

    2025年3月8日 编程技术
    200
  • JS和H5编写推箱子游戏

    推箱子小游戏是一款多年前很流行的小游戏(即使现在也有很多人玩),游戏目的很简单,就是人推箱子,把所有的箱子推到目的地,就游戏成功:看似跟简单的逻辑,其实还是有一定难度的,我也是依靠了别人的帮助才完成的,现在开始介绍如何用js,html5编写…

    2025年3月8日
    200
  • JavaScript和HTML5编写游戏Flappy Bird简易版

    上一篇文章我们和大家分享了JS和H5编写推箱子游戏,本文主要和大家分享用js和H5标签编写经典游戏:Flappy Bird 简易版,希望能帮助到大家。 声明:本人初学js和h5,本文涉及编写方式以及算法如有更好地改进,请各位大佬提出建议~ …

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论