`
羽落窗前
  • 浏览: 107192 次
  • 性别: Icon_minigender_2
  • 来自: 厦门
社区版块
存档分类
最新评论

JavaScript的prototype

 
阅读更多

最近在看一些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文档.rar

    JavaScript中的原型(Prototype)是理解JavaScript继承机制的关键概念。它是一种对象属性,允许一个对象访问并继承另一个对象的属性和方法。在这个“javascript prototype文档”中,我们可以期待深入学习JavaScript...

    javascript prototype原型操作笔记.docx

    ### JavaScript Prototype原型操作知识点 #### 一、Prototype基础概念 **Prototype** 在 JavaScript 中是一个非常重要的概念,它支持面向对象编程中的继承特性。每个 JavaScript 对象都有一个内部属性 `[...

    javascript Prototype 对象扩展.docx

    ### JavaScript Prototype 对象扩展 #### 一、简介与背景 在JavaScript中,`prototype`是一个非常重要的概念,尤其是在面向对象编程(OOP)方面。通过利用`prototype`,开发者能够更高效地管理对象间的共享属性和...

    JavaScriptprototype的深度探索不是原型继承那么简单.pdf

    JavaScriptprototype的深度探索不是原型继承那么简单.pdf

    JavaScript_Prototype(源代码+中文手册).rar

    JavaScript Prototype 是一种重要的编程概念,尤其在Web开发中不可或缺。这个压缩包文件“JavaScript_Prototype(源代码+中文手册).rar”包含了关于JavaScript原型的源代码和中文手册,为学习和理解这一主题提供了...

    JavaScript prototype属性详解

    JavaScript中的`prototype`属性是面向对象编程的关键特性之一,它关联了函数(特别是构造函数)与实例之间的继承关系。每个函数都有一个`prototype`属性,这个属性是一个对象,包含了所有实例共享的方法和属性。当...

    javascript prototype原型详解(比较基础)

    javascript的prototype原型简单介绍: prototype原型是javascript中特别重要的概念,属于必须要掌握,如果没有良好的掌握的话,进一步用好或者学好js基本是不可能的实现的事情,并且此概念稍有难度,可能对于初次接触...

    Advanced JavaScript (closures,prototype,inheritance)

    JavaScript,作为一种广泛应用于Web开发的脚本语言,其高级特性如闭包(closures)、原型(prototype)和继承(inheritance)是理解其精髓的关键。本文将深入探讨这些概念,帮助开发者更好地掌握JavaScript的核心。 ...

    Prototype

    Prototype 是一个广泛使用的JavaScript库,设计目的是为了简化JavaScript的开发,尤其是处理DOM操作、AJAX交互以及事件处理等方面的工作。它通过提供一系列实用的工具函数和面向对象的特性,极大地提高了JavaScript...

    javascript类库prototype.js

    Prototype.js 是一个强大的JavaScript类库,它为开发者提供了丰富的功能,使得创建具有高度互动性和Web2.0特性的富客户端页面变得更为简单。这个库的设计理念是扩展JavaScript的基础对象,提供一套统一且易于使用的...

    JavaScript prototype(原型对象)

    JavaScript prototype(原型对象) 所有的 JavaScript 对象都会从一个 prototype(原型对象)中继承属性和方法。 在前面的章节中我们学会了如何使用对象的构造器(constructor): 实例 function Person(first, ...

    JavaScript Prototype对象

    JavaScript Prototype对象是JavaScript语言中的一个核心特性,它在JavaScript 1.1版本中就已经引入,主要目的是为了实现面向对象编程的继承机制。Prototype对象允许开发者为已存在的对象类型添加新的属性和方法,...

    javascript prototype 原型链

    JavaScript中的原型链(Prototype Chain)是理解面向对象编程在JavaScript中的实现方式的关键概念。原型链是基于原型(Prototype)机制的一种实现,它允许对象继承其他对象的属性和方法。在JavaScript中,每个函数...

    JavaScript prototype对象的属性说明

    一、什么是JavaScript中对象的prototype属性 JavaScript中对象的prototype属性,是用来返回对象类型原型的引用的。我们使用prototype属性提供对象的类的一组基本功能。并且对象的新实例会”继承”赋予该对象原型的...

    javascript prototype原型操作笔记

    JavaScript中的prototype机制是其面向对象编程的核心概念之一,它允许开发者创建具有继承属性和方法的对象。在JavaScript中,几乎所有的对象都是通过某个构造函数或对象字面量创建的,而这些构造函数或对象自身都有...

    JavaScript prototype属性使用说明

    JavaScript中的prototype属性是一个非常重要的概念,它是ECMAScript规范定义的一部分,用于给对象的构造函数添加新方法或者修改现有方法。IE 4引入的prototype属性主要用于面向对象编程中,能够在不改变原有构造函数...

    JavaScript使用prototype定义对象类型

    JavaScript 使用 prototype 定义对象类型 在 JavaScript 中,prototype 是一个非常重要的概念,它提供了一套面向对象编程的基础设施,允许开发者定义对象类型和实现继承。下面我们将详细介绍如何使用 prototype ...

Global site tag (gtag.js) - Google Analytics