从零开始学 Web之JavaScript(五)面向对象

Daotin的梦呓

从零基础学 Web 前端

大家好,这里是「 Daotin的梦呓 」从零开始学 Web 系列教程。此文首发于「Daotin的梦呓」公众号,同时也会同步到我的相关博客,可以从

关于我

找到我的博客地址,也欢迎大家订阅关注。在这里我会从 Web 前端零基础开始,一步步学习 Web 相关的知识点,期间也会分享一些好玩的项目。现在就让我们一起进入 Web 前端学习的冒险之旅吧!

一、面向对象

1、对象创建方式

1.1、调用系统函数创建对象

(创建对象的最简单方式就是创建一个 Object 的实例,然后再为它添加属性和方法。)

缺点:使用同一个接口创建很多对象,会产生大量的重复代码。

1.2、自定义构造函数创建对象

工厂模式创建对象:考虑到在 ECMAScript 中无法创建类,开发人员就发明了一种函数,用函数来封装以特定接口创建对象的细节(把创建一个函数的过程封装在一个函数里面),缺点:创建的对象属性都是一样的。

工厂模式创建对象进阶版:可以修改属性

自定义构造函数:(函数和构造函数的区别:没有区别,但是通常构造函数首字母大写

特点:

没有显式地创建对象;

直接将属性和方法赋给了 this 对象;

没有 return 语句。

进阶(传参数):

构造函数的问题

构造函数模式虽然好用,但也并非没有缺点。使用构造函数的主要问题,就是每个方法都要在每个实例上重新创建一遍。在前面的例子中, person1 和 person2 都有一个名为 sayName()的方法,但那两个方法不是同一个 Function 的实例。不要忘了——ECMAScript 中的函数是对象,因此每定义一个函数,也就是实例化了一个对象。从逻辑角度讲,此时的构造函数也可以这样义。

从这个角度上来看构造函数,更容易明白每个 Person 实例都包含一个不同的 Function 实例(以显示 name 属性)的本质。说明白些,以这种方式创建函数,会导致不同的作用域链和标识符解析,但创建 Function 新实例的机制仍然是相同的。因此,不同实例上的同名函数是不相等的,以下代码可以证明这一点:

然而,创建两个完成同样任务的 Function 实例的确没有必要;况且有 this 对象在,根本不用在执行代码前就把函数绑定到特定对象上面。因此,大可像下面这样,通过把函数定义转移到构造函数外部来解决这个问题。

在这个例子中,我们把 sayName() 函数的定义转移到了构造函数外部。而在构造函数内部,我们将 sayName 属性设置成等于全局的 sayName 函数。这样一来,由于 sayName 包含的是一个指向函数的指针,因此 person1 和 person2 对象就共享了在全局作用域中定义的同一个 sayName() 函数。

1.3、使用对象字面量表示法

对象字面量是对象定义的一种简写形式,目的在于简化创建包含大量属性的对象的过程。

如果留空其花括号,则可以定义只包含默认属性和方法的对象

缺点:一次性对象,无法修改属性的值。

2、访问对象属性

点表示法 和 方括号表示法

从功能上看,这两种访问对象属性的方法没有任何区别。但方括号语法的主要优点是可以通过变量来访问属性(属性绑定),例如:

如果属性名中包含会导致语法错误的字符,或者属性名使用的是关键字或保留字,也可以使用方括号表示法。

例如:

由于"first name"中包含一个空格,所以不能使用点表示法来访问它。然而,属性名中是可以包含非字母非数字的,这时候就可以使用方括号表示法来访问它们。通常,除非必须使用变量来访问属性,否则我们建议使用点表示法。

PS: 如果访问一个没有的属性的值,那么这个值为 undefined,而不是报错?

因为 js 是一门动态类型的语言,不管使用点表示法还是方括号表示法,如果没有这个属性,就相当于在创建这个属性,然而这个时候没有赋值,所以就是 undefined。

3、访问对象方法

4、JSON

什么是JSON

JSON 的全称为:JavaScript Object Notation(JavaScript对象表示形式:就是对象字面量)

JSON格式的数据:一般都是成对的,键值对。

JSON和对象字面量的区别?

json 和对象(对象字面量)的区别仅仅在于,json 格式的数据中的键必须用双引号括起来;

5、字面量的遍历

对象本身没有 length,所以不能用 for 循环遍历。要使用 for…in…

6、值传递和引用类型传递

分析值传递和址传递最好的方法就是画图分析,最简单。

7、内置对象

学习的时候可以查阅在线文档:

MDN 在线文档

菜鸟教程

8、基本包装类型

本身是基本类型,但是在执行的过程中,如果这种类型的变量调用了属性或者方法,那么这种类型就不是基本类型了,而是基本包装类型。这个变量也不是普通变量了,而是基本包装类型的变量。

需要注意的地方:

如果一个,那么结果是true

如果一个,那么结果是对象。

欢迎关注

Daotin的梦呓

如果觉得不错,欢迎分享给其他的小伙伴们 :)

  • 发表于:
  • 原文链接:https://kuaibao.qq.com/s/20180611G1QF3R00?refer=cp_1026
  • 腾讯「云+社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。

扫码关注云+社区

领取腾讯云代金券