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

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

原型prototype是javascript中极其重要的概念之一,但也是比较容易引起混淆的地方。我们需要花费一些时间和精力好好理解原型的概念,这对于我们学习javascript是必须的。...也就是说,原型是函数对象的属性,不是所有对象的属性,对象经过构造函数new出来,那么这个new出来的对象的构造函数有一个属性叫原型。明确这一点很重要。...其实很好理解,javascript中对象是通过引用传递的,原型对象只有一份,不是new出一个对象就复制一份,所以我们对原型的操作和更新,会影响到所有的对象。这就是原型对象的实时性。 ?...Paste_Image.png 自身属性与原型属性 这里涉及到javascript是如何搜索属性和方法的,javascript会先在对象的自身属性里寻找,如果找到了就输出,如果在自身属性里没有找到,那么接着到构造函数的原型属性里去找...所以,如果碰到了自身属性和原型属性里有同名属性,那么根据javascript寻找属性的过程,显然,如果我们直接访问的话,会得到自身属性里面的值。 ?

4.3K30

JavaScript——对象的原型

如机制和原理(对象基于原型)里所记述的那样,JavaScript是一个基于原型的面向对象的语言。本文着重于对原型的实现机制进行剖析和说明。...原型链的实现 JavaScript里所有的对象都有一个名为__proto__的属性,这个属性里面存放的就是对象所参照的原型对象的引用。 ?...原型的自动设置 当通过构造函数创建新对象时,JavaScript会自动将构造函数的prototype属性值设置到新对象的__proto__属性里。...__proto__ = Person.prototype; tom = Person.call(tom,"Tom"); 属性的继承 当访问对象的属性时,JavaScript会通过遍历原型链进行查找,直到找到给定名称的属性为止...而设值对象属性则不会遍历原型链,而是直接将属性添加到该对象自身,并不影响到原型链中的对象。

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

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

    但是每个对象都新建了func()方法,显得多余且浪费资源 为了解决上述问题,就要用到JavaScript的prototype对象:起到共享某些相同属性和方法的作用!...JavaScript的对象都继承自"原型"对象(与java、c++中类相似的作用);除了null,null没有自己的原型 JavaScript原型设计机制:原型上面的属性和方法,都能够被子对象共享 1...构造函数生成对象;构造函数的原型(prototype)属性上面定义的方法或属性被所有实例化对象共享;构造函数的原型属性是实例对象的原型对象。 2.  ...总结: JavaScript的继承机制主要是基于prototype的。...构造函数生成实例化对象;构造函数的prototype属性就是实例化对象的原型对象;原型对象上的属性和方法被所有实例化对象所共享!

    1.1K70

    JavaScript prototype(原型对象)

    所有的 JavaScript 对象都会从一个 prototype(原型对象)中继承属性和方法。...对象都会从一个 prototype(原型对象)中继承属性和方法: Date 对象从 Date.prototype 继承。...所有 JavaScript 中的对象都是位于原型链顶端的 Object 的实例。 JavaScript 对象有一个指向一个原型对象的链。...当试图访问一个对象的属性时,它不仅仅在该对象上搜寻,还会搜寻该对象的原型,以及该对象的原型的原型,依次层层向上搜索,直到找到一个名字匹配的属性或到达原型链的末尾。...Date 对象, Array 对象, 以及 Person 对象从 Object.prototype 继承。 添加属性和方法 有的时候我们想要在所有已经存在的对象添加新的属性或方法。

    29610

    JavaScript——对象的属性

    在JavaScript中,所有的对象都是一组属性的集合,属性可以是数值,字符串等原始类型,也可以是函数,或者是其他对象。 属性的类型 JavaScript中的属性有两种类型:数据属性和访问器属性。...属性的继承 属性可以通过对象的原型链进行继承。...,因此访问objC.prop1时,JavaScript将会按照objC—>objB—>objA的原型链进行顺序查找,最后从objA中取出该属性值。...事实上,JavaScript中的数组(Array),本质上也是一个键/值对的集合,数值类型的自然索引也是作为属性名(键)存在的。...修改已有数据属性的值(即使该属性可写) 但可以 修改已有访问器属性的值(如果有set方法) 相关方法汇总 属性的相关方法都是以Object的静态方法或原型方法的形式提供的,下面简单的做一下汇总: 属性定义相关

    2.4K30

    JavaScript之面向对象学习二(原型属性对象与in操作符)获取对象中所有属性的方法

    // person1所指向的原型属性对象里面含有name属性,所以person1实例能够访问"name"属性。...所以这里在person1实例中找到了name属性,则JS就不会再去原型属性对象那个中寻找该属性,原型对象中的同名属性就会被忽略 alert(person1.hasOwnProperty("name...false; 注意:这里的属性可以是对象实例的属性,也可以是对象实例的[[Prototype]]属性指针,所指向的原型对象; 下面是结合Object.hasOwnProperty()和in判断一个属性到底是实例属性...@param name ---需要判断的对象属性 功能:判断name是实例的原型属性对象的属性还是实例的实例属性 */ function hasPrototypePrototype...in操作符之for-in结合使用 在使用for-in循环时,返回的是所有能够通过对象访问的、可枚举的属性,既包括实例中的属性又包括原型对象中的属性; 注意:屏蔽了原型中不可枚举属性(即将[[Enumerable

    1.6K90

    图解JavaScript对象原型与原型链

    Javascript中抽象的原型链概念: 橙黄色实心代表函数,函数是可执行的对象; 橘红色圈圈代表prototype属性,且总是存在于函数对象中; 蓝紫色带箭头线段代表原型链的走向; 蓝绿色实心代表普通对象...圈圈+实心组合形式的含义: 橘红色圈圈+黄色实心代表prototype属性为函数对象; 橘黄色圈圈+蓝绿色实心代表prototype属性为普通对象; 图中,prototype属性就是可以被继承的原型,...原型可以是函数,也可以是普通对象,没有原型的对象为数不多,Object.prototype就是其中之一,如图中右侧所示Object.prototype原型链箭头指向null,这里是所有原型链的终点,也意味着原型链到此结束...__proto__ === Function.prototype // true 几乎所有内置的构造函数的prototype属性都是普通对象,但构造函数Function除外,因为Function.prototype...,因为Object.prototype自身也是对象,它的原型却是null,也可说它没有原型,也可以说它的原型是空。

    55320

    JavaScript面向对象与原型

    javaScript有两种开发模式:1.函数式(过程化),2.面向对象(OOP)。面向对象的语言有一个标志,那就是类的概念,而通过类可以创建任意多个具有相同属性和方法的对象。...但是,javaScript没有类的概念,因此它的对象也与基于类的语言中的对象有所不同。 一.创建对象 创建一个对象,然后给这个对象新建属性和方法。...二.原型 我们创建的每个函数都有一个prototype(原型)属性,这个属性是一个对象,它的用途是包含可以由特定类型的所有实例共享的属性和方法。...proto属性是实例指向原型对象的一个指针,它的作用就是指向构造函数的原型属性constructor。通过这两个属性,就可以访问到原型里的属性和方法了。...原型对象不仅仅可以在自定义对象的情况下使用,而javaScript内置的引用类型都可以使用这种方式,并且内置的引用类型本身也使用了原型。

    761100

    javascript面向对象与原型

    昨天我们讲了在面向对象中创建对象的几种方式 工厂模式 构造函数模式 工厂模式创建的对象,像工厂一样来创建对象,创建的每一个对象都是通过new Object()来创建的,原型直指Object() 构造函数似乎不错...$wx = Wx 这时候就用到了原型 我之前就用了大量篇幅讲过javascript的原型,这次遇到了面向对象,换个角度再次讨论 原型模式创建对象 我们创建的每个函数都有一个prototype(原型)属性...,这个属性是一个指针,指向一个对象,而这个对象的用途是包含可以由特定类型的所有实例共享的属性和方法。...使用原型对象的好处是可以让所有对象实例共享它所包含的属性和方法。 也就是说,不用再构造函数中定义对象的实例信息,而是将这些属性和方法添加到原型对象中 一个?...实例属性屏蔽同名的原型属性 在实例中添加属性,使这个属性和原型中的属性同名,这个属性会屏蔽掉(也可以理解为覆盖掉)原型中的那个属性 继续?的?

    38040

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

    这张图片有点劝退了,哈哈哈~ 通过原型机制,JavaScript 中的对象从其他对象继承功能特性;这种继承机制与经典的面向对象编程语言的继承机制不同。...JavaScript 常被描述为一种基于原型的语言 (prototype-based language)——每个对象拥有一个原型对象,对象以其原型为模板、从原型继承方法和属性。...在 JavaScript 中并不如此复制——而是在对象实例和它的构造器之间建立一个链接(它是__proto__属性,是从构造函数的prototype属性派生的),之后通过上溯原型链,在构造器中找到这些属性和方法...注意:没有官方的方法用于直接访问一个对象的原型对象——原型链中的“连接”被定义在一个内部属性中,在 JavaScript 语言标准中用 [[prototype]] 表示(参见 ECMAScript)。...JavaScript 中到处都是通过原型链继承的例子。比如,你可以尝试从 String、Date、Number 和 Array 全局对象的原型中寻找方法和属性。

    1.1K30

    从JavaScript原型到面向对象

    本文来由:今天下午,笔者和一个做后端的同学一起聊天,聊到了JavaScript语言本身的相关内容,不可否认JavaScript本身确实有很多不可回避的问题,同学还指出说JavaScript连面向对象的没有...虽然在 ES6 中引入了 class 关键字,但它只是一个语法糖,本质还是基于JavaScript 的原型来实现的。...JavaScript的原型 说起JavaScript的面向对象,就必须要聊Javascript的原型。...,都有一个私有属性( proto__ 属性),这个私有属性指向它的构造函数的原型对象(构造函数的prototype属性指向的对象 ),该原型对象也会有一个自己的私有属性( __proto ) ,然后它指向的构造函数的...prototype属性指向的对象,然后这样一层层的向上直到一个对象的原型对象为 null,即代表JavaScript的原型到了顶层。

    56210

    javascript对象属性的赋值解析

    age: 12} Dog.prototype = Animal; var dog2 = new Dog(12); console.log(dog2);//{age: 12} dog2对象的...name属性不见了,why?...概念: 在segmentfault社区找到相关概念: 当为一个对象属性赋值是要遵循以下规则: 当对象的原型链中的原型对象上有对应的属性名,但是其是只读的,那么对象属性的赋值操作无效; 当对象的原型链中的原型对象上有对应的属性名...,但是其是可写的,且设置了set方法,那么对象属性的赋值操作无效,转而调用调用原型对象中的属性的set方法; 当对象的原型链中的原型对象上有没有对应的属性名,那么直接在当前对象上添加这个属性(如果没有这个属性...'name'只读,所以再次赋值无效 //通过知道属性只读,对象属性赋值操作无效,那么我们可以更改name的property-wirteable为true,如下 Object.defineProperty

    1.8K30

    JavaScript之面向对象的概念,对象属性和对象属性的特性简介

    但ECMAScript(指定JavaScript标准的机构,也就是说JavaScript是实现其标准的扩展)并没有类的概念,因此他的对象和基于类的语言中的对象有所不同,ECMAScript把对象定义为:...//JavaScript早期的对象定义方式 var person = new Object(); person.name = "张三"; person.age...应为ECMA-262规范中提到属性的特性是为了实现JavaScript引擎所用到,所以我们不能通过JavaScript直接访问,但是JavaScript给我们提供了了一个方法,来操作我们需要操作的对象的属性的特性...;这个方法是 //这个方法接收三个参数:属性所在的对象引用、属性的名字和一个描述符对象 //其中描述符对象的属性必须是上面提到的四个属性的特性(实现JavaScript引擎所用...最终的对象和上一段代码定义的对象相同。唯一的区别是这里的属性都是在同一时间创建的!上一段代码中定义的对象,实在定义完数据属性之后又定义了一个访问器属性。

    2.3K60

    JavaScript学习总结(四)——this、原型链、javascript面向对象

    ,在JavaScript中,原型也是一个对象,通过原型可以实现对象的属性继承,JavaScript的对象中都包含了一个" prototype"内部属性,这个属性所对应的就是该对象的原型。...在JavaScript中,原型也是一个对象,通过原型可以实现对象的属性继承,JavaScript的对象中都包含了一个”[[Prototype]]”内部属性,这个属性所对应的就是该对象的原型。...在JavaScript的原型对象中,还包含一个”constructor”属性,这个属性对应创建所有指向该原型的实例的构造函数 1.2、typeof与instanceof 1.2.1、typeof 在 JavaScript...当查找一个对象的属性时,JavaScript 会向上遍历原型链,直到找到给定名称的属性为止,到查找到达原型链的顶部(也就是 Object.prototype),如果仍然没有找到指定的属性,就会返回 undefined...当查找一个对象的属性时,JavaScript 会向上遍历原型链,直到找到给定名称的属性为止,到查找到达原型链的顶部(也就是 Object.prototype),如果仍然没有找到指定的属性,就会返回 undefined

    1.5K70

    深入理解javascript中的继承机制(3)属性复制对象之间的继承深复制原型继承原型继承与属性复制的混合使用

    属性复制 下面我们就实现这样一种继承方式,将父亲的原型对象的属性全部复制到子对象的原型属性中 function extend2(Child, Parent) { var p = Parent.prototype...对象之间的继承 extend2中,我们都是以构造器创建对象为基础的,我们将原型对象中的属性一一拷贝给子原型对象,而这两个原型本质上也是对象。现在我们考虑不通过原型,直接在对象之间拷贝属性。...Paste_Image.png 我们可以看到这种直接复制对象,不通过原型和构造器,的继承模式比较简单,直接复制,子对象有需要添加的属性,直接更改或添加就可以了。...原型继承与属性复制的混合使用 我们知道实现继承就是将已有的功能归为所有,我们在new一个新对象的时候,应该继承于现有对象,然后再为其添加额外的属性与方法。...原型继承可以在新建一个对象的时候,将已有对象设置为新的对象的原型。 属性拷贝,就是在新建一个对象之后,将另一个已有对象的属性拷贝过来。 我们将这两项功能放在一个函数中。

    1.5K20

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

    接着下一个代码块在Person.prototype(Person的原型属性对对象)中添加了一个方法sayHello(); 根据输出,我们发现即使friend实例是在添加新方法之前创建的,但它任然可以访问这个新方法...其原因可以归结为实例与原型之间的松散连接关系,当我们调用friend.sayHello()时,首先会在实例中搜索名为sayHello的属性方法,如果实例属性中没有,则会继续去搜索原型。...而原型与实例之间是通过[[prototype]]指针相连接的(实例通过[[prototype]]指针指向原型属性对象来调用原型中的方法和属性),正因为[[prototype]]是一个指针,并不是Person...的副本,所以即使修改(添加)原型的方法在创建完实例之后,该实例任然可以访问完成修改之后的原型对象!...从上面的图我们可以看出,重写原型对象之后,并没有是对象实例的[[prototype]]指针的值发生改变,它还是指向最初的原型对象。

    57390
    领券