原型、原型对象和原型链

news/2024/11/17 21:25:17/

原型: __ proto __
原型对象: prototype
每个对象中都有 __ proto __

一、构造函数和原型

ES6之前并没有引入类的概念,对象不是基于类创建的,是用一种称为构造函数的特殊函数来定义的。

创建对象的三种方式:

1.通过new Object()
var obj1 = new Object()
2.对象字面量 {}
var obj1 = { }
3.自定义构造函数
把对象的公共部分抽取出来放到构造函数中,通过构造函数创建不同的对象

function Star(uname,age){this.uname = uname;this.age = age;this.sing = function(){console.log('唱歌')}
}
var ldh = new Star('刘德华'18)//创造的对象实例
ldh.sing();

(1). 构造函数

一种特殊的函数,主要用来初始化对象(为对象成员变量赋初始值),与new一起使用。把对象中的公共属性和方法抽取处理,然后封装到这个函数中。
注意:

  • 构造函数用于创建一类对象,首字母要大写
  • 要和new一起使用

new在执行时会做四件事:

  1. 会在内存中创建一个新的空对象
  2. 让this指向这个对象
  3. 执行构造函数中的代码,将属性和方法进行赋值操作
  4. 返回创建的这个实例对象
  • 静态成员:在构造函数本身上添加的成员 ,静态成员只能通过构造函数来访问
  • 实例成员:构造函数内部通过this添加的成员,实例成员只能通过实例化的对象来访问,不可以通过构造函数来访问

每次实例化一个对象都会开辟一个内存空间,会存在浪费空间的问题 。
我们让所有对象使用同一个函数,这样会比较节省内存。

(2). 构造函数原型对象prototype

构造函数通过原型分配的函数是所有对象所共享的,不用单独开辟内存空间。
每一个构造函数中都有一个prototype属性,指向另一个对象。
我们可以把不变的方法,直接定义在prototype对象上,这样所有对象的实例可以共享这些方法。

//在构造函数的原型对象上添加sing方法
Star.prototype.sing = function(){console.log('我会唱歌')
}
var ldh = new Star('刘'18)var zxy = new Star('张'18)//两个实例可以使用sing方法
ldh.sing();
zxy.sing();

一般情况下,我们把公共属性定义到构造函数中,公共的方法放到原型对象身上。

(3). 对象原型_ proto _

每一个对象身上系统自动添加一个_proto _属性,指向构造函数的原型对象(也就是prototype),所以对象才可以使用原型对象的属性和方法。

(4).constructor构造函数

在对象原型_ proto _和构造函数原型对象prototype里都有一个属性constructor,我们称为构造函数,它指回构造函数本身。
**作用:**主要用于记录该对象引用了哪个构造函数,它可以让原型对象重新指向原来的构造函数

Star.prototype = {
//手动添加constructor,重新指回构造函数Starconstructor:Star,sing: function(){},movie: function(){}
}

因为方法太多,我们给原型对象赋值的是一个对象,这样会把原来的对象constructor给覆盖了,所以就要手动添加constructor,让它指回这个构造函数。

二、构造函数、实例、原型对象三者关系

(1). 构造函数和原型对象的关系

每个构造函数中都有一个原型对象,通过构造函数中的prototype指向这个原型对象;
原型对象中有一个属性constructor,指回了这个构造函数。

在这里插入图片描述

(2). 构造对象、实例、原型对象的关系

通过构造函数通过new创建一个实例对象,构造函数指向这个对象实例;
每个实例对象中有proto,指向了原型对象prototype
在这里插入图片描述

三、原型链

  1. prototype原型对象里面的_ proto _原型指向的是Object.prototype;
  2. Object原型对象里面的_proto _ 原型指向为null;
  3. 只要是对象都会有一个原型_proto_,指向原型对象prototype;
    原型对象也有一个原型 _ proto _,指向Object原型对象prototype;
    在这里插入图片描述

四、JS的成员查找机制

按照原型链的机制查找:
1.当访问一个对象的属性(方法)时,首先查找这个对象自身是否有该属性;
2.如果没有就通过__ proto __ 查找它的原型,_ proto _ 指向的prototype原型对象;
3.如果还没有就通过原型对象的原型,prototype.__ proto __ 指向Object的原型对象;
4.以此类推一直找到Object的原型对象,在通过Object的原型对象的原型最终指向的是null;
注意:查找时,优先使用对象身上的成员,就近原则。
_ proto _ 对象原型的意义是为对象成员查找机制提供一个方向。在实际开发中不可以使用这个属性,它只是内部指向原型对像prototype


http://www.ppmy.cn/news/484829.html

相关文章

带你了解原型链

了解原型链可以先看我上期发布的帖子再来看这篇会更好的理解: 详解原型对象_loulansd的博客-CSDN博客 问:什么是原型链? 得先知道什么是对象,比如一个物品一只笔就是对象,他的属性可以是黑色彩色的它的方法可以是写字,包括我们生活的万物都有自身的属性,那么我们就可以理解万…

原型和原型链(二)

文章目录 前言一、_proto_(上文提到)1、定义:2、小测试: 二、原型链1、定义及相关解释:2、原型链图: 前言 在上篇文章中对构造函数和原型对象进行了相应的总结。此文章将会对原型链进行详细的阐述。希望大家对原型和原型链的理解…

原型链的解说

首先,我们要知道,万物皆对象,一切的一切都是由对象构成的。 一、关于函数的原型对象 在JavaScript中,如果我们创建一个函数A,那么浏览器就会在内存空间里创建一个对象B,而且每个函数都会默认会有一个属性…

【js进阶】-原型/原型链

一、构造函数创建对象 我们先使用构造函数创建一个对象,先来认识下构造函数 function Person() { } var person1 new Person(); person1.name 张三; console.log(person1.name) // 张三在这个例子中,Person 就是一个构造函数,我们使用 ne…

JS原型、原型链到底是什么?

前言 在js的学习中,原型毫无疑问是一个难点,但也是一个不可忽视的重点。在前端面试中也是一个高频考题,在接下来的深入学习中,你会发现原型、原型链等知识点其实并不难。 1. “一切皆为对象” JavaScript是一个面向&#xff08…

原型及原型链 ①

文章目录 原型及原型链函数对象constructor 构造函数new 操作符将构造函数当作函数构造函数的问题prototype 原型理解原型对象更简单的原型语法原型的动态性原生对象的原型原型对象的问题构造函数和原型结合构造函数和原型结合 __proto__原型链关卡 本文转:https://…

原型原型链深度解析

原型 原型是函数特有的,构造函数制造出对象的公共祖先。通过该构造函数产生的对象,可以继承该原型的属性和方法。 我们先写一个构造函数 function Person() {} var person new Person(); person.name luoxi; console.log(person.name) // luoxi在这…

原型,原型链,原型的继承

原型的作用? 1.节省内存空间 2.实现数据共享(继承) 什么是原型? 任何一个函数都有propotype属性,它本身是一个对象,我们称之为原型 构造函数,实例化对象与原型之间的关系? 1.任何一个函数都有prototype属性,它本身是一个对象,我们称之为原型 2.构造函数也是函数,也都…