首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

JavaScript——对象的原型

如机制和原理(对象基于原型)里所记述的那样,JavaScript是一个基于原型的面向对象的语言。本文着重于对原型的实现机制进行剖析和说明。...原型链的实现 JavaScript里所有的对象都有一个名为__proto__的属性,这个属性里面存放的就是对象所参照的原型对象的引用。 ?...通过Object.getPrototypeOf()可以获得指定对象的原型对象,这也是被推荐的使用方法。但__proto__属性是可读写的,这也意味着程序可以通过该属性动态的改变对象的原型对象。...原型的自动设置 当通过构造函数创建新对象时,JavaScript会自动将构造函数的prototype属性值设置到新对象的__proto__属性里。...由于这个查值过程是一个遍历过程,所以当属性的值越靠近顶层,查找性能就会越低,而当值靠近底层时,查找性能就会高很多,所以在编写复杂的应用时,一定要提防原型链过长而带来的性能问题。

59310

深入理解javascript中的原型原型的概念使用原型给对象添加方法和属性使用原型对象的属性和方法原型的陷阱小结

---- 使用原型给对象添加方法和属性 不使用原型,使用构造函数给对象添加属性和方法的是通过this,像下面这样。...Paste_Image.png ---- 使用原型对象的属性和方法 我们使用原型的对象和方法不会在直接在构造函数上使用,而是通过构造函数new出一个对象,那么new出来的对象就会有构造函数原型里的属性和方法...其实很好理解,javascript中对象是通过引用传递的,原型对象只有一份,不是new出一个对象就复制一份,所以我们对原型的操作和更新,会影响到所有的对象。这就是原型对象的实时性。 ?...这就是javascript中的原型陷阱。 我们很容易解决这个问题,只要在更新原型对象后面,重新指定构造函数即可。 Dog.prototype.constructor = Dog; ?...Paste_Image.png 这样所有就按正常的运行了 ** 所以我们切记在替换掉原型对象之后,切记重新设置constructor.prototype ** 小结 我们大概介绍了原型中容易混淆的问题,

4.3K30
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    JavaScript之面向对象学习六原型模式创建对象的问题,组合使用构造函数模式和原型模式创建对象

    一、仔细分析前面的原型模式创建对象的方法,发现原型模式创建对象,也存在一些问题,如下: 1、它省略了为构造函数传递初始化参数这个环节,结果所有实例在默认的情况下都将取得相同的属性值,这还不是最大的问题!...2、最大的问题是原型中的所有属性是被很多实例所共享的,这种共享对于函数非常合适,对于那些包含基本值的属性也说得过去,因为我们知道可以在实例上添加一个同名属性,可以隐藏原型中的对应属性。...,发现person2同时也被添加了一个朋友,但这并不是我们想要的,而这正是因为原型模式的共享的本性所导致的,只要任何一个实例修改了原型属性对象中的属性值,所有与该原型对象关联的实例都会受到影响!...二、组合使用构造函数模式和原型模式 为了解决原型模式不能初始化参数和共享对于引用模式所存在的问题!...这种构造函数与原型组合的模式创建自定义类型,是ECMAScript中使用最广泛、认同度最高的一种创建自定义类型的方法。可以说,这是用来定义引用类型的一种默认模式。

    1.4K60

    深度剖析前端JavaScript中的原型(JS的对象原型)

    这张图片有点劝退了,哈哈哈~ 通过原型机制,JavaScript 中的对象从其他对象继承功能特性;这种继承机制与经典的面向对象编程语言的继承机制不同。...JavaScript 常被描述为一种基于原型的语言 (prototype-based language)——每个对象拥有一个原型对象,对象以其原型为模板、从原型继承方法和属性。...在传统的 OOP 中,首先定义“类”,此后创建对象实例时,类中定义的所有属性和方法都被复制到实例中。...你可能会认为,this 关键字指向当前对象的原型对象,其实不是(还记得么?原型对象是一个内部对象,应当使用 __proto__ 访问)。...这种继承模型下,上游对象的方法不会复制到下游的对象实例中;下游对象本身虽然没有定义这些方法,但浏览器会通过上溯原型链、从上游对象中找到它们。这种继承模型提供了一个强大而可扩展的功能系统。

    1.1K30

    对Javascript 类、原型链、继承的理解

    一、序言   和其他面向对象的语言(如Java)不同,Javascript语言对类的实现和继承的实现没有标准的定义,而是将这些交给了程序员,让程序员更加灵活地(当然刚开始也更加头疼)去定义类,实现继承。...(例如每个人都要吃饭,而吃饭这个方法就是一个非静态方法) 2.Javascript对类的实现 a.利用函数创建类,利用new关键字生成实例对象  (话不多说,先上代码,以下没有特别说明的话,我都会先上代码...在Javascript中,每当我们定义一个构造函数,Javascript引擎就会自动为这个类中添加一个prototype(也被称作原型) 2.对象的 proto 是什么?    ...在Javascript中,每当我们使用new创建一个对象时,Javascript引擎就会自动为这个对象中添加一个__proto__属性,并让其指向其类的prototype // 代码3.2 function...这就是Javascript著名的原型链的结果啦。话不多说,先上图: ? 当我们访问person.name时,发生了什么呢?

    66710

    JavaScript之面向对象学习四原型对象的动态性

    1、由于在原型中查找值的过程是一次搜索,因此我们对原型对象所做的任何修改都能够立即从实例上反映出来---即便是先创建了实例后修改原型也是如此。...的副本,所以即使修改(添加)原型的方法在创建完实例之后,该实例任然可以访问完成修改之后的原型对象!...但是如果重写整个原型对象,那么情况就不一样了,在前面的随笔中曾说过,当调用构造函数创建一个对象实例时JS会为实例添加一个指向最初原型(也就是Person.prototype)的[[prototype]]...指针,而像下面的代码中那样,把原型修改成另外一个对象,并不能改变实例中的[[prototype]]指针的值(说明白点,就是实例还是指向最初原型); 注意:实例中的[[prototype]]仅指向最初原型...从上面的图我们可以看出,重写原型对象之后,并没有是对象实例的[[prototype]]指针的值发生改变,它还是指向最初的原型对象。

    57390

    JavaScript的原型继承在使用中存在的安全问题

    JavaScript的原型很多人都知道也很好用,但是很多人在使用原型继承中导致的安全问题却很少人知道,接下来我们就来好好了解一下。...在真实开发中,我们经常会在代码中使用Property accessors 属性访问器,并且使用用户输入的参数去访问某个对象的属性。...这看起来可能是一个很稀疏平常的操作,但是往往在这个过程中我们的代码就已经产生了一个很大的安全漏洞!!!为什么这样写代码会产生安全问题?...假设黑客知道你的代码在运行时会创建一个新对象,并且你没有使用Object.create(null)创建一个没有原型的对象。...在代码中减少属性访问器的使用尽可能使用.的方式去访问对象的属性或者使用 Map或Set,来代替我们的对象检查对象的原型链,查看新创建对象的原型是否被恶意添加了原本不该有的属性,或者属性被修改检查用户的输入

    19211

    【说站】JavaScript对象原型__ proto__的介绍

    JavaScript对象原型__ proto__的介绍 1、__proto__对象原型和原型对象 prototype 是等价的。 2、意义在于为对象的查找机制提供一个方向。...但是作为非标准属性,因此实际开发中,不可以使用这个属性,它只是内部指向原型对象prototype。... = function() {         console.log('正在哼哼唧唧的唱歌...');     }     let zs = new People('张三');     //实例对象身上并没有...__proto__ == People.prototype);     // true       console.log(zs); 以上就是JavaScript对象原型__ proto__的介绍,希望对大家有所帮助...更多Javascript学习指路:Javascript 推荐操作环境:windows7系统、jquery3.2.1版本,DELL G3电脑。

    26510

    【说站】Javascript中对象原型 __proto__的介绍

    Javascript中对象原型 __proto__的介绍 说明 1、所有对象都会有一个属性__proto__指向构造函数的prototype原型对象....之所以我们可以使用构造函数prototype原型对象的属性和方法,是因为对象有__proto__原型。 2、__proto__对象原型的意义在于为对象的搜索机制提供一个方向或一条路线....但它是一个非标准属性,所以在实际开发中不能使用这个属性,它只是指原型对象prototype。... __proto__ 指向我们构造函数的原型对象 prototype         console.log(ldh..../ 如果么有sing 这个方法,因为有__proto__ 的存在,就去构造函数原型对象prototype身上去查找sing这个方法      以上就是Javascript中对象原型 _

    48710

    JavaScript继承的实现方式:原型语言对象继承对象原理剖析

    在经典的面向对象语言中,您可能倾向于定义类对象,然后您可以简单地定义哪些类继承哪些类(参考C++ inheritance里的一些简单的例子),JavaScript使用了另一套实现方式,继承的对象函数并不是通过复制而来...,而是通过原型链继承 回顾《再谈javascriptjs原型与原型链及继承相关问题》 什么是原型语言  只有对象,没有类;对象继承对象,而不是类继承类。 ...原型语言创建有两个步骤  使用”原型对象”作为”模板”生成新对象 :这个步骤是必要的,这是每个对象出生的唯一方式。以原型为模板创建对象,这也是”原型”(prototype)的原意。 ... call 无法继承父类原型属性/方法的问题 // Object.create 方法接受传入一个作为新创建对象的原型的对象,创建一个拥有指定原型和若干个指定属性的对象 // 通过这种方法指定的任何属性都会覆盖原型对象上的同名属性...使用父类的构造函数来增强子类实例,等于是复制父类的实例属性给子类(没用到原型) function Woman(name){  //继承了People,子类的this传给父类   People.call

    79120

    JavaScript技巧:扩展和优化Math对象的方法

    扩展“Math”对象JavaScript提供了一个Math对象,涵盖了各种有用的常数和函数。然而,有时候可能会遇到缺少某个函数或者内置函数无法提供所需功能的情况。...但幸运的是,JavaScript是一种灵活的语言,有一些方法可以帮助解决这个问题。扩展“Math”对象事实上,JavaScript对象没有任何访问保护可以被视为一个弱点。...但在我们目前的情况下,这是一个优点。你可以很容易地修改现有函数,甚至向“Math”对象添加新函数。下面是一个例子,round()函数不允许设置小数。但这可以很容易地解决:Math....我们还可以向Math对象添加一些有用的内容:Math.PI2 = 2*Math.PI// Range-Check: True if x in Range (L .....在这里,你可以使用对象解构:let {sin, cos, round, inRange, constrain, PI, PI2} = Math现在这些函数在全局范围内都是可用的:round(sin(0.1

    20200

    【说站】javascript原型链继承的使用

    javascript原型链继承的使用 说明 1、即使不自定义类型,也可以通过原型实现对象之间的信息共享。 2、原型链继承非常适合不需要单独创建构造函数的场合,当仍然需要在对象之间共享信息时。...但是要记住,属性中包含的引用值总是会在相关对象之间共享,和使用原型一样。... object(o) {    function F() {}    F.prototype = o;    return new F();} 这个object()函数将创建一个临时构造函数,并将传入的对象赋予该构造函数的原型...object()本质上是对传入对象进行浅复制。 以上就是javascript原型链继承的使用,希望对大家有所帮助。...更多Javascript学习指路:Javascript 推荐操作环境:windows7系统、jquery3.2.1版本,DELL G3电脑。 收藏 | 0点赞 | 0打赏

    32410

    Javascript 原型链之原型对象、实例和构造函数三者之间的关系

    2017-10-13 10:14:59 首先来说一下名词解释,首先说一下prototype,每个函数都有一个prototype属性,这个属性是指向一个对象的引用,这个对象称为原型对象,原型对象包含函数实例共享的方法和属性...,也就是说将函数用作构造函数调用(使用new操作符调用)的时候,新创建的对象会从原型对象上继承属性和方法。...至于__porto__属性,在 javascript 中每个对象都会有一个 __proto__ 属性,当我们访问一个对象的属性时,如果这个对象内部不存在这个属性,那么他就会去 __proto__ 里找这个属性...在javascript当中除了undefined和null外都有__proto__,但是只有function对象才有prototype属性,其他任何类型的值都没有。...即使是使用new方法从function构造出的实例对象也没有prototype属性。

    63910

    几行代码立即理解js的对象,类,原型等概念

    很多人觉得js的类和对象及原型这个概念特别难理解,特别是习惯java,php,C#等高级语言编程的同学们。 无意中找到了下面一组代码,貌似一下子理解了js中的原型,类,对象等概念。...(); p1.IntroduceChinese(); 1、对象方法理解就很简单了,主要是如果类生成一个实例,那么该实例就能使用该方法 2、类方法,不需要通过生成实例就可以使用的方法 3、原型方法主要是用来对...JS已有的系统对象进行扩展而生的,例如Array数组没有什么方法,你可以为其增加原型方法,那么创建的数组就拥有了该方法。...1、对象方法包括构造函数中的方法以及构造函数原型上面的方法; 2、类方法,其实这里的类就是一个函数,在js中由于函数也是一个对象,所以可以为函数添加属性以及方法,这种方法在node中用的比较多; 3...原来原型方法就是事后定义类,所有类的实例都可以调用原型方法 而定类方法 ,就好比定义静态类的静态方法 ,只能用静态类的方式调用。

    83320

    JavaScript OOP(三):prototype原型对象(即构造函数的prototype属性)

    但是每个对象都新建了func()方法,显得多余且浪费资源 为了解决上述问题,就要用到JavaScript的prototype对象:起到共享某些相同属性和方法的作用!...JavaScript的对象都继承自"原型"对象(与java、c++中类相似的作用);除了null,null没有自己的原型 JavaScript原型设计机制:原型上面的属性和方法,都能够被子对象共享 1...(a3.constructor===a1.constructor);//true 注意原型对象被覆盖可能出现的问题: 1 function Abc(){}; 2 Abc.prototype.constructor...__proto__:内部属性,不应该对使用者显露;尽量减少使用这个属性 __pro__:设置对象的原型对象;其实一般都可以用Object.getPrototypeOf()和Object.setPrototypeOf...返回一个新对象 Object.create():以参数为原型对象生成新对象 __proto__属性:设置对象的原型对象;尽量减少使用该属性 instanceof:判断对象是否是某构造函数的实例对象 自己用

    1.1K70

    《你不知道的JavaScript(上)之原型对象》读书笔记

    ,避免原型对象扩展带来的干扰 if (Object.prototype.hasOwnProperty.call(source, key)) { ///判断是否为...最好使用类把过程化风格的“意大利面代码”转换成结构清晰、组织良好的代码。4.2 类的机制一个类就是一张蓝图。...使用 for..in 遍历对象时,使用 in 操作符来检查属性在对象中是否存在时,同样会查找对象的整条原型链5.1.1 [[Prototype]] 的“尽头”所有普通的 [[Prototype]] 链最终都会指向内置的...虽然这些 JavaScript 机制和传统面向类语言中的“类初始化”和“类继承”很相似,但 是 JavaScript 中的机制有一个核心区别,那就是不会进行复制,对象之间是通过内部的 [[Prototype...出于各种原因,以“继承”结尾的术语(包括“原型继承”)和其他面向对象的术语都无 法帮助你理解 JavaScript 的真实机制(不仅仅是限制我们的思维模式)。

    65130

    JavaScript学习笔记022-原型链0原型继承0对象的深浅拷贝extends

    ) // new fn()是类的实例化 // obj = new fn(),obj就是fn类的实例 /* 原型:prototype 原型的本质,是个json格式的对象 一个对象,是被这个对象对应的类所实例出来的...// 请求数据时,先向原型请求,没有找到就继续向原型的原型请求,直到最顶层Objet的原型,如果都没有,就会抛出错误 // 原型也是一个对象,所以它也有对应的类的原型 // 一层一层的原型的链式关系,...// 使用对象的形式定义类 Person.prototype = { constructor: Person, // 必须把指向加上 add (){} } // 最顶层对象原型的继承 Object.prototype.fengyu...= function (){ console.log(this); // this指向调用它的字符串 } "123".fengyu(); // 最顶层对象原型的扩展方法,任何对象都能调用,不推荐使用...; // 继承私有属性 基类 // 自行扩展属性 this.sex = opt.sex; } // 继承公有属性 // 方案一:P2的原型成为P1的原型(pass) P2.prototype = P1

    41110

    【JavaScript】内置对象 ① ( 内置对象简介 | JavaScript 中的三类对象 - 自定义对象 内置对象 浏览器对象 | 常用的内置对象 )

    一、JavaScript 内置对象简介 1、JavaScript 中的三类对象 - 自定义对象 / 内置对象 / 浏览器对象 在 JavaScript 中 , 对象可以分为三类 : 自定义对象 , 内置对象...; 内置对象 : 是 JavaScript 语言本身提供的对象 , 提供了一些常用的或最基本的功能 ; 内置对象 在 JavaScript 环境初始化时就已经存在 , 可以直接使用 , 不需要手动创建...; 浏览器对象 : 这是 浏览器提供的 JavaScript 代码 与 网页 和 浏览器本身 交互的对象 , 这些对象 允许 JavaScript 代码 与 浏览器窗口 / 文档 / 历史记录 等进行交互...; 2、JavaScript 中常用的内置对象 JavaScript 内置对象 是 JavaScript 语言的自带对象 , 这些对象 提供给 开发者用于实现 常用 的 最基本功能 , 借助 内置对象...键值对 数据 ; Set : ES6 引入的 数据结构 , 用于存储 唯一值 数据 ; JSON : 提供 JSON 处理相关功能 ; 3、代码示例 - Math 内置对象使用示例 Math 对象用于解决复杂的数学问题

    37210
    领券