刚开始接触对象原型时大脑就开始起义了,脑子就转不灵清了。就感觉怎么着这个概念就是灌输不进去,俗称断路。后面找了很多资料,最主要的还是要借助于《JavaScript语言精髓》这本书,让我对这此豁然开朗,希望说的不对的地方请给予指正,谢谢。

一、什么是原型?

  原型包含一个对象("prototype"对象),是构造函数特有的属性。将所有实例对象共享的属性和方法放在里面,不需要共享的属性和方法则放在构造函数里面。它能继承私有和共享属性和方法。

二、prototype实例

  首先创建一个构造函数,具有name属性。

        function Person(name){
this.name = name;
}

  构造函数创建好之后,我想创建两个实例,并且输出他们的name值。

        var p1 = new Person("张三");
var p2 = new Person("李四");
console.log(p1.name+","+p2.name); /* 输出张三,李四*/

  那现在我想给p1张三在添加一个eat属性,我要他可以吃饭(food),那既然你张三都可以吃饭,那我李四要要吃饭,那我也输出p2.eat,但是结果是undefined……如下所示。

        p1.eat = "food";
console.log(p1.eat); /* 输出food */
console.log(p2.eat); /* 输出undefined */

  原来是张三自己偷偷摸摸的去吃饭,没让李四知道,哎╮(╯▽╰)╭。那既然这样,Person就不得不添加一个共用属性eat了,得让大家一起吃饭呀。

        Person.prototype.eat = "food";
console.log(p1.eat); /* 输出food */
console.log(p2.eat); /* 输出food,我也可以吃饭了…… */

  添加Person.prototype.eat = "food"这个以后,eat属性就被添加到原型库中,eat属性就可以共享了(李四说“太好了,我也可以吃饭了o(≧v≦)o~~”)。这个属性和方法(方法类似处理)的问题就解决了,那如果出现两个对象Person和Student,Person还是具有构造函数的name属性和用prototype添加的eat属性,我想让Student继承Person中所有的属性和方法,请看第三点。

三、prototype继承实例

  首先创建Person和Student构造函数(为了方便看,构造函数和实例输出一起写了)。

        function Person(name){
this.name = name;
}
Person.prototype.eat = "food";
function Student(name,eat){
Person.apply(this,arguments); /* 继承构造函数,即私有属性 */
}
var s1 = new Student("王五","food");
console.log(s1.name); /* 输出 王五 */
console.log(s1.eat); /* undefined */

  Student要继承Person中的属性,添加Person.apply(this,arguments) (标注:apply中this表示实例化的对象s1,arguments是new Student()中的参数,这是系统执行的),表示Student继承Person中属性。创建一个实例s1,s1输出正常,为什么s1.eat输出undefined?Person中不是已经添加了eat属性吗?为什么还不行呢?我找啊找,最终发现原来是Person.apply(this,arguments)只能继承构造函数中的属性,哎,真是弱爆了。那我想要继承原型中的属性怎么办?那容易,请看下面代码。

        Student.prototype = new Person(); /* 继承原型,即共享属性 */
var s1 = new Student("王五","food");
console.log(s1.name); /* 输出 王五 */
console.log(s1.eat); /* 输出 food */

  添加一个Student.prototype = new Person()就可以了。

  这里做一个特别解释:

  Student具有prototype这个属性的原因是因为它是一个function一个构造函数,前面我提到过,这个是构造函数特有的属性。如果student是这样的。

var student = {
name: "张三"
}

  那就要报错了,说student不是一个function。这个是大家特别注意的。

  还有为什么要new Person()呢,这个和java中类似,但是在javascript中只针对于构造函数(构造函数中函数命名和类命名类似,首字母要大写),其他不需要new。

  有哪里讲解的不好或者是不正确的地方,希望大家能第一时间反馈给我,希望和大家共同进步,谢谢。

  

  

对原型prototype的详解的更多相关文章

  1. Javascript中prototype属性详解 (存)

    Javascript中prototype属性详解   在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不 ...

  2. 最详尽的 JS 原型与原型链终极详解,没有「可能是」。(一)

    最详尽的 JS 原型与原型链终极详解,没有「可能是」.(一) 第二篇已更新,点击进入第三篇已更新,点击进入

  3. JS原型与原型链终极详解(转)

    JavaScript原型及原型链详解 一. 普通对象与函数对象 JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object,Function 是JS自带的函数对象. ...

  4. ProtoType原型和__Proto__原型链的详解

    var arr = new Array(12,13,14,15,16,17,18); var arr2 = new Array(12,13); arr.sun=function(){ //用原型加Ar ...

  5. js重点--原型链继承详解

    上篇说过了关于原型链继承的问题,这篇详解一下. 1. function animals(){ this.type = "animals"; } animals.prototype. ...

  6. 【repost】JS原型与原型链终极详解

    一. 普通对象与函数对象  JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函数对象.下面举例说明 function f ...

  7. Javascript中prototype属性详解

    在典型的面向对象的语言中,如java,都存在类(class)的概念,类就是对象的模板,对象就是类的实例.但是在Javascript语言体系中,是不存在类(Class)的概念的,javascript中不 ...

  8. JS原型与原型链终极详解

    一. 普通对象与函数对象  JavaScript 中,万物皆对象!但对象也是有区别的.分为普通对象和函数对象,Object ,Function 是JS自带的函数对象.下面举例说明 function f ...

  9. JS 原型链图形详解

    JS原型链 这篇文章是「深入ECMA-262-3」系列的一个概览和摘要.每个部分都包含了对应章节的链接,所以你可以阅读它们以便对其有更深的理解. 对象 ECMAScript做为一个高度抽象的面向对象语 ...

随机推荐

  1. log4j1 插入mysql

    做任务需要用到这样的需求: 使用log4j 1.2进行日志管理. 将日志输出到mysql中 系统数据库表利用脚本每日生成一张,插入系统运行时特定的表中. 实现方法 properties(放在项目根目录 ...

  2. iBATIS sqlMapConfig配置详解

    <?xml version="1.0" encoding="UTF-8" ?> <!DOCTYPE sqlMapConfig PUBLIC & ...

  3. 获取request的变量

    由于IP代码未实现,先注释掉. package com.helloweenvsfei.servlet; import java.io.IOException; import java.io.Print ...

  4. [转]Oracle数据库中的约束

    SQL 约束 约束用于限制加入表的数据的类型. 可以在创建表时规定约束(通过 CREATE TABLE 语句),或者在表创建之后也可以(通过 ALTER TABLE 语句). 我们将主要探讨以下几种约 ...

  5. 5.9-2比较str1和str2截取后的子串

    package zfc; public class ZfcShcq { public static void main(String[] args) { // TODO Auto-generated ...

  6. 【CodeForces 297C】Splitting the Uniqueness

    题意 序列s有n个数,每个数都是不同的,把它每个数分成两个数,组成两个序列a和b,使ab序列各自去掉个数后各自的其它数字都不同. 如果存在一个划分,就输出YES,并且输出两个序列,否则输出NO. 分析 ...

  7. HDU-1754I Hate It 线段树区间最值

    这道题比较基本,就是用线段树维护区间最值,可以算是模板吧-.. I Hate It Time Limit: 9000/3000 MS (Java/Others) Memory Limit: 32768 ...

  8. BZOJ3626 LCA

    Description 给出一个n个节点的有根树(编号为0到n-1,根节点为0).一个点的深度定义为这个节点到根的距离+1. 设dep[i]表示点i的深度,LCA(i,j)表示i与j的最近公共祖先. ...

  9. UVA 11527 Unique Snowflakes

    用STL做会很方便 SET: /*by SilverN*/ #include<iostream> #include<algorithm> #include<cstring ...

  10. Syntax error, annotations are only available if source level is 1.5

    在项目上右键 -> Properties -> Java Compiler