最近在看一些web开发的知识教程,觉得关于prototype的这段需要记录一下。
对于js的每一个object,都有internal property,可以通过obj.proName或者obj['proName']来调用。通过obj.hasOwnProperty('proName')可以检查obj是否有相对于的属性。
对于普通的object, property的使用方法如下:
new person = new Object();
person.name = "unknown";
person.sayName = fuction(){
alert('The name is '+this.name+'.');
}
//call sayName function
person.sayName(); // The name is unknown.
alert(person.hasOwnProperty('sayName'); // true
alert(typeof person.sayName); // function
使用这种方法创建出来的object是独立的。如果要用js来进行面向对象的编程,就需要用到prototype.
对于js来说,function是一种特殊的对象,而且好像只有function对象可以调用prototype,来完成类似于面向对象编程的创建类,继承等等。
构造方法:
var Person = function(name){
this.name = name;
};
Person.prototype.sayName = function(){
alert('The name is '+this.name+'.');
};
var mike = new Person('Mike');
mike.sayName(); // The name is Mike.
这里的mike获得了Person的所有prototype的属性和值。需要注意的是,这时候:
1. 当Person再次添加新的prototype属性,mike也会同时获得这个属性。
Person.prototype.age = 'unknown';
Person.prototype.tellAge = function(){
alert('Age is '+this.age+'.');
};
mike.tellAge(); // Age is unknown.
2. 但是,当mike修改了这个属性的值之后,无论Person如何修改,都不会影响到mike的属性。
mike.age = 20;
Person.prototype.age = 0;
mike.tellAge();// Age is 20.
3. 同理,如果mike先添加了一个新的property值,此后Person再添加同名的prototype,不会影响到mike。
如果说这里的Person相当于一个面向对象里的类的话,那么js里也有类似于子类父类的继承。方法如下:
var Student = function(name){
this.name = name;
}
Student.prototype = new Person();
var tom = new Student('Tom');
tom.sayName(); // The name is Tom.
在这里,Person属性变化对tom的影响关系和mike是相同的。
附件里的是今天学习prototype时候写的练习代码。
分享到:
相关推荐
JavaScript中的原型(Prototype)是理解JavaScript继承机制的关键概念。它是一种对象属性,允许一个对象访问并继承另一个对象的属性和方法。在这个“javascript prototype文档”中,我们可以期待深入学习JavaScript...
### JavaScript Prototype原型操作知识点 #### 一、Prototype基础概念 **Prototype** 在 JavaScript 中是一个非常重要的概念,它支持面向对象编程中的继承特性。每个 JavaScript 对象都有一个内部属性 `[...
### JavaScript Prototype 对象扩展 #### 一、简介与背景 在JavaScript中,`prototype`是一个非常重要的概念,尤其是在面向对象编程(OOP)方面。通过利用`prototype`,开发者能够更高效地管理对象间的共享属性和...
JavaScriptprototype的深度探索不是原型继承那么简单.pdf
JavaScript Prototype 是一种重要的编程概念,尤其在Web开发中不可或缺。这个压缩包文件“JavaScript_Prototype(源代码+中文手册).rar”包含了关于JavaScript原型的源代码和中文手册,为学习和理解这一主题提供了...
JavaScript中的`prototype`属性是面向对象编程的关键特性之一,它关联了函数(特别是构造函数)与实例之间的继承关系。每个函数都有一个`prototype`属性,这个属性是一个对象,包含了所有实例共享的方法和属性。当...
javascript的prototype原型简单介绍: prototype原型是javascript中特别重要的概念,属于必须要掌握,如果没有良好的掌握的话,进一步用好或者学好js基本是不可能的实现的事情,并且此概念稍有难度,可能对于初次接触...
JavaScript,作为一种广泛应用于Web开发的脚本语言,其高级特性如闭包(closures)、原型(prototype)和继承(inheritance)是理解其精髓的关键。本文将深入探讨这些概念,帮助开发者更好地掌握JavaScript的核心。 ...
Prototype 是一个广泛使用的JavaScript库,设计目的是为了简化JavaScript的开发,尤其是处理DOM操作、AJAX交互以及事件处理等方面的工作。它通过提供一系列实用的工具函数和面向对象的特性,极大地提高了JavaScript...
Prototype.js 是一个强大的JavaScript类库,它为开发者提供了丰富的功能,使得创建具有高度互动性和Web2.0特性的富客户端页面变得更为简单。这个库的设计理念是扩展JavaScript的基础对象,提供一套统一且易于使用的...
JavaScript prototype(原型对象) 所有的 JavaScript 对象都会从一个 prototype(原型对象)中继承属性和方法。 在前面的章节中我们学会了如何使用对象的构造器(constructor): 实例 function Person(first, ...
JavaScript Prototype对象是JavaScript语言中的一个核心特性,它在JavaScript 1.1版本中就已经引入,主要目的是为了实现面向对象编程的继承机制。Prototype对象允许开发者为已存在的对象类型添加新的属性和方法,...
JavaScript中的原型链(Prototype Chain)是理解面向对象编程在JavaScript中的实现方式的关键概念。原型链是基于原型(Prototype)机制的一种实现,它允许对象继承其他对象的属性和方法。在JavaScript中,每个函数...
一、什么是JavaScript中对象的prototype属性 JavaScript中对象的prototype属性,是用来返回对象类型原型的引用的。我们使用prototype属性提供对象的类的一组基本功能。并且对象的新实例会”继承”赋予该对象原型的...
JavaScript中的prototype机制是其面向对象编程的核心概念之一,它允许开发者创建具有继承属性和方法的对象。在JavaScript中,几乎所有的对象都是通过某个构造函数或对象字面量创建的,而这些构造函数或对象自身都有...
JavaScript中的prototype属性是一个非常重要的概念,它是ECMAScript规范定义的一部分,用于给对象的构造函数添加新方法或者修改现有方法。IE 4引入的prototype属性主要用于面向对象编程中,能够在不改变原有构造函数...
JavaScript 使用 prototype 定义对象类型 在 JavaScript 中,prototype 是一个非常重要的概念,它提供了一套面向对象编程的基础设施,允许开发者定义对象类型和实现继承。下面我们将详细介绍如何使用 prototype ...