1. 对象,属性

前面看到对象里删除属性一直疑惑,什么是对象,为什么属性可以删除, 我印象里的属性还是停留在property, 总想不明白为什么属性竟然能够删除。直到看到标准库才明白,原来对象就是python里的字典,这个属性就是python里字典的key. delete就是删掉字典里面指定的一个值。这么简单的事如果有老师讲解会容易很多,用专业术语写出来的东西,作为新手真是费了好大劲才琢磨明白。

?  对象应该与python里的字典不完全一样,JS的对象包括数组、函数、三种原始类型(数值、字符串、布尔值)在一定条件下,也会自动转为对象。

书里面向对象一章解释了对象和属性:

对象是一个容器,封装了属性(property)和方法(method). 属性是对象的状态,方法是对象的行为(完成某种任务).

例如,可以把动物抽象为animal 对象, 使用属性记录具体是哪一种动物, 使用方法表示动物的某种行为。

? 如果属性是状态,那可以理解为什么能删除一种发生。但是上个例子中, 如果属性是动物类目,怎么能删除?属性到底是什么?怎么用?

window: 代表取全局变量。

2. 构造函数

C++ /Java是典型的面向对象编程语言,存在”类“(class) 这个概念。

”类“ 就是对象的模板,对象就是”类“的实例。

但是JavaScript 语言的对象体系,不是基于"类"的, 而是基于构造函数(constructor) 和原型链(prototype).

JavaScript 语言使用构造函数 (consttructor)作为对象的模板。 所谓”构造函数“,就是专门用来生成对象的函数。它提供模板,描述对象的基本结构。一个构造函数,可以生成多个对象, 这些对象都有相同的结构。

构造函数的写法就是一个普通的函数,但是有自己的特征和用法。为了与变通函数区别,构造函数名字的第一个字母通常大写。

 var Vehicle = function(){
this.price=1000;
};

构造函数的特点:
   > 函数体内部使用了this 关键字,代表了所要生成的对象实例。

> 生成对象的时候,必需用new命令,调用Vehicle函数。

new 命令 : 作用就是执行构造函数,返回一个实例对象。

 var Vehicle = function(){
this.price =1000;
}; var v=new Vehicle();
v.price //

上面代码通过new命令,让构造函数Vehicle生成一个实例对象,保存在变量v中。这个新生成的实例对象,从构造函数Vehicle继承了price属性。买  new 命令执行时,构造函数内部的this,就代表了新生成的实例对象,this.price表示实例对象有一个price属性, 值是1000.

使用new 命令时,根据需要,构造函数也可以接受参数。

 var Vehicle = function(p){
this.price=p;
}; var v =new Vehicle(500);

new 命令本身就可以执行构造函数,所以后面的构造函数可以带括号,也可以不带括号。下面两行代码是等价的:

 var v=new Vehicle();
var v=new Vehicle;

new 命令的原理

使用new命令时, 它后面的函数调用就不是正常的调用,而是依次执行下面的步骤:

1. 创建一个空对象,作为将要返回的对象实例。

2. 将这个空对象的原型,指向构造函数的Prototype属性。

3. 将这个空对象赋值给函数内部的this关键字。

4. 开始执行构造函数内部的代码。

构造函数内部,this指的是一个新生成的空对象,所有针对this的操作,都会发生在这个空对象上。 构造函数的目的就是操作一个空对象(即this 对象),将其构造成需要的样子。

如果构造函数内部有return语句,而且return后面跟着 个对象,new 命令会返回return语句指定的对象;否则,就会不管return语句,返回this对象。

 var Vehicle =function(){
this.price =1000;
return 1000;
}; (new Vehicle())===1000
// false

上面代码中, 构造函数Vehicle的return 语句一个数值。这时,new命令就会忽略这个return语句,返回构造后的this对象。但是,如果return语句是一个跟this无关的新对象,new 命令会返回这个新对象,而不是this对象。例:

 var Vehicle = function(0{
this.price=1000;
return{price:2000};
}; (new Vehicle()).price
//

上面代码中,构造函数Vehicle的return语句,返回的是一个新对象,new 命令会返回这个对象,而不是this 对象。

另一方面,如果对变通函数(内部没有this关键字的函数)使用new 命令,则会返回一个空对象。

 function getMessage(){
return "this is a messgae";
} var msg=new getMessage(); msg//{}
typeof msg //"object"

上面代码中,getMessage是一个变通函数,返回一个字符串。对它使用new命令,会得到一个空对象,这是因为new命令总是返回一个对象,要么是实例对象,要么是return语句指定的对象,本例中, return语句返回的是字符串,所以new命令就忽略了该语句。

Java Script 读书笔记 (四) 面向对象编程的更多相关文章

  1. 读书笔记-JavaScript面向对象编程(一)

    PDF下载链接: http://pan.baidu.com/s/1eSDSTVW 密码: 75jr 第1章 引言 1.1 回顾历史 1.2 变革之风 1.3 分析现状 1.4 展望未来 1.5 面向对 ...

  2. 读书笔记-JavaScript面向对象编程(三)

    第7章 浏览器环境 7.1 在HTML页面中引入JavaScript代码 7.2概述BOM与DOM(页面以外事物对象和当前页面对象) 7.3 BOM 7.3.1 window对象再探(所以JavaSc ...

  3. 《Effective Java》读书笔记 - 8.通用编程

    Chapter 8 General Programming Item 45: Minimize the scope of local variables local variables应该在他们要被用 ...

  4. Java Script 读书笔记 (三) 函数

    1. 函数作用域 在函数内部定义的变量,外部无法读取,称为"局部变量"(local variable). 变量v在函数内部定义,所以是一个局部变量,函数之外就无法读取. 函数内部定 ...

  5. 《Effective Java》读书笔记四(泛型)

    Java1.5发行版本中增加了泛型(Generic).在没有泛型之前,从集合中读取到的每一个对象都必须进行转换.如果有人不小心插入了错误的类型对象,在运行时的转换处理就会出错.有了泛型之后,可以告诉编 ...

  6. 读书笔记-JavaScript面向对象编程(二)

    第5章 原型 5.1 原型属性(所有函数拥有一个prototype属性,默认为空对象) 5.1.1 利用原型添加方法和属性 function Gadget(name,color){ this.name ...

  7. Java并发编程的艺术读书笔记(2)-并发编程模型

    title: Java并发编程的艺术读书笔记(2)-并发编程模型 date: 2017-05-05 23:37:20 tags: ['多线程','并发'] categories: 读书笔记 --- 1 ...

  8. Java并发编程的艺术读书笔记(1)-并发编程的挑战

    title: Java并发编程的艺术读书笔记(1)-并发编程的挑战 date: 2017-05-03 23:28:45 tags: ['多线程','并发'] categories: 读书笔记 --- ...

  9. Python:笔记(3)——面向对象编程

    Python:笔记(3)——面向对象编程 类和面向对象编程 1.类的创建 说明:和Java不同的是,我们不需要显示的说明类的字段属性,并且可以在后面动态的添加. 2.构造函数 构造函数的功能毋庸置疑, ...

随机推荐

  1. DTN学习,theONE模拟器网络相关资料整理

    下面是一个百度空间的: http://hi.baidu.com/jensenliao 博客园的一篇博客:theONE模拟器简介(主要讲述,软件配置,软件结构) http://www.cnblogs.c ...

  2. rubygem若干常用选项参数

    可以用gem help commands看所有支持的参数,这个比gem -h显示的全: wisy@wisy-ThinkPad-X61:~/src/ruby_src$ gem help commands ...

  3. java常用数据库连接池 (DBCP、c3p0、Druid) 配置说明

    1. 引言 1.1 定义 数据库连接是一种关键的有限的昂贵的资源,这一点在多用户的网页应用程序中体现得尤为突出.对数据库连接的管理能显著影响到整个应用程序的伸缩性和健壮性,影响到程序的性能指标.数据库 ...

  4. jQuery之select的option怎样绑定事件

    HTML: <select id='select'> <option value='0'>上海</option> <option value='1'>北 ...

  5. c#调用野狗云 rest api

    野狗云就不多介绍了,这里主要是记录一下c#调用他们提供的rest api,把数据post到野狗云存储,直接上代码 static void Main(string[] args) { string st ...

  6. Centos7 时区的设置

    Linux 系统(我特指发行版, 没说内核) 下大部分软件的风格就是不会仔细去考虑向后 的兼容性, 比如你上个版本能用这种程序配置, 没准到了下一个版本, 该程序已经不见了. 比如 sysvinit ...

  7. .net c#获取自定义Attribute

    前言: 在c#开发中,有时候我们需要读取 Attribute中的信息(关于Attribute , 我自己把他理解成一个可以为类,属性标记的东西,这个标记可以为你提供一些关于类,方法,属性的额外信息) ...

  8. gradle 将依赖打入Jar包的方法

    使用的是IDEA,直接引入 plugins { id 'com.github.johnrengelman.shadow' version '1.2.3' } 放在build.gradle的最上面,然后 ...

  9. .net捕捉全局未处理异常的3种方式

    前言: 我们在实际项目开发中,经常会遇到一些不可预见的异常产生,有的异常在程序运行时就对其进行处理(try)但是,有的程序不需要每一个地方都用try进行处理,那么针对这种情况,可以参照下面的方式,实现 ...

  10. C#System.Text.RegularExpressions.Regex使用(二) .

    (6)特殊字符的匹配 string x = "//"; Regex r1 = new Regex("^////$"); Console.WriteLine(&q ...