借这篇文章理清一下自己的思路,同时也希望能给和我同样一知半解的同学理清一下思路。引发思考来自于我犯的一个错误,错误代码是这样的:

1 var o = {
2     ...
3 }
4 var obj = new o();

结果不用说,当然是报错的。遗憾的是我以前一直以为var o = { }是定义了一个叫做o的类。然后自己理了一下。得出一下结论:

var o = {}; 等价于 var o = new Object(); 但不等价于 var o = function(){};

第一二种形式 o是一个对象,Object类的对象。第三种形式 o是一个function,更重要的是o是一个类。

1 var o = {};
2 o.oField = "oField";

等价于

1 var o = {
2     oField : "oField"
3 }

那问题是:对象上怎么可以直接定义属性呢?

由于o是Object类的对象,所以o.prototype是undefined 所以不能这样 o.prototype.oField = ...

另外,在思考过程中,我写了两段测试代码,一并贴上。可以算是个笔记吧。

01 //定义类
02 var Engin = function(){};
03  
04 //实例属性
05 Engin.prototype.objectField = "objectField";
06  
07 //类属性(静态域)
08 Engin.classField = "classField";
09  
10 //实例方法
11 Engin.prototype.objectMethod = function(){
12     document.write("objectMethod is called<br/>");
13 }
14 //类方法(静态方法)
15 Engin.classMethod = function(){
16     document.write("classMethod is called<br/>");
17 }
18  
19 //调用实例方法
20 new Engin().objectMethod();
21  
22 //调用类方法
23 Engin.classMethod();
24  
25 document.write(new Engin().objectField + "<br/>");
26 document.write(Engin.classField + "<br/>");
27  
28 //只能遍历出类属性和类方法
29 //怎么遍历出实例属性和实例方法呢?
30 document.write("使用for in 遍历Engin对象===============================<br/>");
31 for(var in Engin){
32     document.write(o+"<br/>");
33 }
34 document.write("=======================================================<br/>");
01 //定义父类Parent,并在父类里定义了一个属性pField和一个方法pMethod
02 var Parent = function(){
03     this.pField = "pField";
04     this.pMethod = function(){
05         document.write("pMethod is called<br/>");
06     }
07 };
08 //定义父类静态属性
09 Parent.staticPField = "staticPField";
10 //定义父类静态方法
11 Parent.staticPMethod = function(){
12     document.write("staticPMethod is called<br/>");
13 }
14 //定义子类Child,并在子类里定义了一个属性cField和一个方法cMethod
15 var Child = function(){
16     this.cField = "cField";//实例属性
17     this.cMethod = function(){//实例方法
18         document.write("cMethod is called<br/>");
19     }
20 };
21 //定义子类静态属性
22 Child.staticCField = "staticCField";
23 //定义子类静态方法
24 Child.staticCMethod = function(){
25     document.write("staticCMethod is called<br/>");
26 }
27 //指定Child继承自Parent
28 Child.prototype =  new Parent();
29  
30 //创建子类对象
31 var childObj = new Child();
32 document.write(childObj.pField+"<br/>");//子类对象访问父类实例属性
33 //document.write(childObj.staticPField+"<br/>");//子类对象不能访问父类静态属性
34 childObj.pMethod();//子类对象调用父类实例方法
35 //childObj.staticPMethod();//子类对象不能调用父类静态方法
36 document.write(childObj.cField+"<br/>");//子类对象访问自己的实例属性
37 document.write(Child.staticCField+"<br/>");//必须使用类名访问自己的静态属性
38 childObj.cMethod();//子类对象调用自己的实例方法
39 Child.staticCMethod();//必须使用类名来调用自己的静态方法

理清一下JavaScript面向对象思路的更多相关文章

  1. javascript面向对象系列第三篇——实现继承的3种形式

    × 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...

  2. Javascript面向对象(封装、继承)

    Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...

  3. 深入理解Javascript面向对象编程

    深入理解Javascript面向对象编程 阅读目录 一:理解构造函数原型(prototype)机制 二:理解原型域链的概念 三:理解原型继承机制 四:理解使用类继承(继承的更好的方案) 五:建议使用封 ...

  4. 转:javascript面向对象编程

    作者: 阮一峰 日期: 2010年5月17日 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学 ...

  5. JavaScript面向对象旅程(下)

    JavaScript面向对象旅程 剪不断,理还乱,是离愁. 前面已经提到过新语言开发的两个步骤,分别是:一.定义基本的数据类型,完善结构化编程语言的设计:二.为函数类型绑定this的概念,好在对象的方 ...

  6. JavaScript面向对象(三)——继承与闭包、JS实现继承的三种方式

      前  言 JRedu 在之前的两篇博客中,我们详细探讨了JavaScript OOP中的各种知识点(JS OOP基础与JS 中This指向详解 . 成员属性.静态属性.原型属性与JS原型链).今天 ...

  7. (三)Javascript面向对象编程:非构造函数的继承

    Javascript面向对象编程:非构造函数的继承   这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现"继承". 今天是最后一个部分,介绍不使 ...

  8. (二)Javascript面向对象编程:构造函数的继承

    Javascript面向对象编程:构造函数的继承   这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继承 ...

  9. Javascript面向对象编程(三):非构造函数的继承(对象的深拷贝与浅拷贝)

    Javascript面向对象编程(三):非构造函数的继承   作者: 阮一峰 日期: 2010年5月24日 这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现&quo ...

随机推荐

  1. 【Mybatis】 逆向生成工程

    前言: 必需学会Maven and SQL基础知识 简介: 通过 Maven, Mybatis 逆向生成 Pojo, Mapper, Example(本章屏蔽了) 工具: JDK8 apache-ma ...

  2. Django常用命令总结

    安装Django: pip install django 指定版本  pip3 install django==2.0 新建项目: django-admin.py startprject mysite ...

  3. 【springmvc+mybatis项目实战】杰信商贸-3.需求分析与数据库建模

    开发步骤需求:生产厂家信息维护基础表FACTORY_C 1.业务需求:a)<需求说明书>     1)描述业务功能     生产厂家模块     功能:为在购销合同模块中的货物信息和附件信 ...

  4. ionic 组件学习

    利用css列表多选框: <div class="{{Conceal}}" > <ion-checkbox color="secondary" ...

  5. n! 阶乘

    其实1.2.3.4.6.7…都是可以不用考虑的,因此选择以5为迭代步数即可. 首先,这些数字都可以不用进行%5(对5取余数)运算,因此每次循环时可以直接将函数的count变量直接加1.其次,考虑25. ...

  6. LeetCode 135——分发糖果

    1. 题目 2. 解答 初始化左序奖赏全为 1,从左往右遍历,如果右边的人评分比左边高,右边奖赏比左边奖赏增 1. 初始化右序奖赏全为 1,从右往左遍历,如果左边的人评分比右边高,左边奖赏比右边奖赏增 ...

  7. 各类4G手机进入工参模式查看手机信息

    随着移动4G正式商用,LTE网络建设日益完善,LTE用户日趋增多,通过进入其工程模式读取服务小区电平RSRP.物理小区标识PCI和频点号等基本信息的方式来判断测试点信号质量的优劣.由于市场上商用终端品 ...

  8. POJ 2208 Pyramids(求四面体体积)

    Description Recently in Farland, a country in Asia, a famous scientist Mr. Log Archeo has discovered ...

  9. 3DMAX2016安装教程【图文】

    下载安装包之后,双击setup.exe. 下面是安装图片教程: 点击安装 点击下一步. 如图输入序列号和产品密钥. 填写安装路径,然后下一步. 开始安装,等待. 安装成功.

  10. 3dContactPointAnnotationTool开发日志(十)

      要是那几个状态栏不能拖动的话岂不是显得太呆板了,于是我又参考Unity官方视频教程学习了如何实现拖动状态栏的功能,还挺简单的.   比如说要拖动这个PanelStatus面板,我只让使用者通过拖动 ...