借这篇文章理清一下自己的思路,同时也希望能给和我同样一知半解的同学理清一下思路。引发思考来自于我犯的一个错误,错误代码是这样的:
结果不用说,当然是报错的。遗憾的是我以前一直以为var o = { }是定义了一个叫做o的类。然后自己理了一下。得出一下结论:
var o = {}; 等价于 var o = new Object(); 但不等价于 var o = function(){};
第一二种形式 o是一个对象,Object类的对象。第三种形式 o是一个function,更重要的是o是一个类。
等价于
那问题是:对象上怎么可以直接定义属性呢?
由于o是Object类的对象,所以o.prototype是undefined 所以不能这样 o.prototype.oField = ...
另外,在思考过程中,我写了两段测试代码,一并贴上。可以算是个笔记吧。
02 |
var Engin = function (){}; |
05 |
Engin.prototype.objectField = "objectField" ; |
08 |
Engin.classField = "classField" ; |
11 |
Engin.prototype.objectMethod = function (){ |
12 |
document.write( "objectMethod is called<br/>" ); |
15 |
Engin.classMethod = function (){ |
16 |
document.write( "classMethod is called<br/>" ); |
20 |
new Engin().objectMethod(); |
25 |
document.write( new Engin().objectField + "<br/>" ); |
26 |
document.write(Engin.classField + "<br/>" ); |
30 |
document.write( "使用for in 遍历Engin对象===============================<br/>" ); |
32 |
document.write(o+ "<br/>" ); |
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/>" ); |
09 |
Parent.staticPField = "staticPField" ; |
11 |
Parent.staticPMethod = function (){ |
12 |
document.write( "staticPMethod is called<br/>" ); |
14 |
//定义子类Child,并在子类里定义了一个属性cField和一个方法cMethod |
15 |
var Child = function (){ |
16 |
this .cField = "cField" ; //实例属性 |
17 |
this .cMethod = function (){ //实例方法 |
18 |
document.write( "cMethod is called<br/>" ); |
22 |
Child.staticCField = "staticCField" ; |
24 |
Child.staticCMethod = function (){ |
25 |
document.write( "staticCMethod is called<br/>" ); |
28 |
Child.prototype = new Parent(); |
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面向对象系列第三篇——实现继承的3种形式
× 目录 [1]原型继承 [2]伪类继承 [3]组合继承 前面的话 学习如何创建对象是理解面向对象编程的第一步,第二步是理解继承.本文是javascript面向对象系列第三篇——实现继承的3种形式 [ ...
- Javascript面向对象(封装、继承)
Javascript 面向对象编程(一):封装 作者:阮一峰 Javascript是一种基于对象(object-based)的语言,你遇到的所有东西几乎都是对象.但是,它又不是一种真正的面向对象编程( ...
- 深入理解Javascript面向对象编程
深入理解Javascript面向对象编程 阅读目录 一:理解构造函数原型(prototype)机制 二:理解原型域链的概念 三:理解原型继承机制 四:理解使用类继承(继承的更好的方案) 五:建议使用封 ...
- 转:javascript面向对象编程
作者: 阮一峰 日期: 2010年5月17日 学习Javascript,最难的地方是什么? 我觉得,Object(对象)最难.因为Javascript的Object模型很独特,和其他语言都不一样,初学 ...
- JavaScript面向对象旅程(下)
JavaScript面向对象旅程 剪不断,理还乱,是离愁. 前面已经提到过新语言开发的两个步骤,分别是:一.定义基本的数据类型,完善结构化编程语言的设计:二.为函数类型绑定this的概念,好在对象的方 ...
- JavaScript面向对象(三)——继承与闭包、JS实现继承的三种方式
前 言 JRedu 在之前的两篇博客中,我们详细探讨了JavaScript OOP中的各种知识点(JS OOP基础与JS 中This指向详解 . 成员属性.静态属性.原型属性与JS原型链).今天 ...
- (三)Javascript面向对象编程:非构造函数的继承
Javascript面向对象编程:非构造函数的继承 这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现"继承". 今天是最后一个部分,介绍不使 ...
- (二)Javascript面向对象编程:构造函数的继承
Javascript面向对象编程:构造函数的继承 这个系列的第一部分,主要介绍了如何"封装"数据和方法,以及如何从原型对象生成实例. 今天要介绍的是,对象之间的"继承 ...
- Javascript面向对象编程(三):非构造函数的继承(对象的深拷贝与浅拷贝)
Javascript面向对象编程(三):非构造函数的继承 作者: 阮一峰 日期: 2010年5月24日 这个系列的第一部分介绍了"封装",第二部分介绍了使用构造函数实现&quo ...
随机推荐
- 【Mybatis】 逆向生成工程
前言: 必需学会Maven and SQL基础知识 简介: 通过 Maven, Mybatis 逆向生成 Pojo, Mapper, Example(本章屏蔽了) 工具: JDK8 apache-ma ...
- Django常用命令总结
安装Django: pip install django 指定版本 pip3 install django==2.0 新建项目: django-admin.py startprject mysite ...
- 【springmvc+mybatis项目实战】杰信商贸-3.需求分析与数据库建模
开发步骤需求:生产厂家信息维护基础表FACTORY_C 1.业务需求:a)<需求说明书> 1)描述业务功能 生产厂家模块 功能:为在购销合同模块中的货物信息和附件信 ...
- ionic 组件学习
利用css列表多选框: <div class="{{Conceal}}" > <ion-checkbox color="secondary" ...
- n! 阶乘
其实1.2.3.4.6.7…都是可以不用考虑的,因此选择以5为迭代步数即可. 首先,这些数字都可以不用进行%5(对5取余数)运算,因此每次循环时可以直接将函数的count变量直接加1.其次,考虑25. ...
- LeetCode 135——分发糖果
1. 题目 2. 解答 初始化左序奖赏全为 1,从左往右遍历,如果右边的人评分比左边高,右边奖赏比左边奖赏增 1. 初始化右序奖赏全为 1,从右往左遍历,如果左边的人评分比右边高,左边奖赏比右边奖赏增 ...
- 各类4G手机进入工参模式查看手机信息
随着移动4G正式商用,LTE网络建设日益完善,LTE用户日趋增多,通过进入其工程模式读取服务小区电平RSRP.物理小区标识PCI和频点号等基本信息的方式来判断测试点信号质量的优劣.由于市场上商用终端品 ...
- POJ 2208 Pyramids(求四面体体积)
Description Recently in Farland, a country in Asia, a famous scientist Mr. Log Archeo has discovered ...
- 3DMAX2016安装教程【图文】
下载安装包之后,双击setup.exe. 下面是安装图片教程: 点击安装 点击下一步. 如图输入序列号和产品密钥. 填写安装路径,然后下一步. 开始安装,等待. 安装成功.
- 3dContactPointAnnotationTool开发日志(十)
要是那几个状态栏不能拖动的话岂不是显得太呆板了,于是我又参考Unity官方视频教程学习了如何实现拖动状态栏的功能,还挺简单的. 比如说要拖动这个PanelStatus面板,我只让使用者通过拖动 ...