Web/04-JavaScript基础/09-对象简介.md
2020-05-30 23:24:59 +08:00

194 lines
5.4 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

## 对象简介
### 面向对象简介
面向对象可以创建自定义的类型很好的支持继承和多态
面向对象的特征封装继承多态
### 对象的概念
JavaScript 对象是一组**无序**的相关属性和方法的集合
**对象的作用是封装信息**比如Student类里可以封装学生的姓名年龄成绩等
对象具有**特征**属性**行为**方法
### 为什么需要对象
保存一个值时可以使用**变量**保存多个值一组值可以使用**数组**
比如如果要保存一个人的信息通过数组的方式可以这样保存
```javascript
var arr = ['王二', 35, '男', '180'];
```
上面这种表达方式比较乱而如果用JS中的**对象**来表达**结构会更清晰**如下
```javascript
var person = {};
person.name = '王二';
person.age = 35;
person.sex = '男';
person.height = '180';
```
由此可见对象里面的属性均是**键值对**
- 相当于属性名
- 相当于属性值可以是任意类型的值数字类型字符串类型布尔类型函数类型等
### 两条补充
**补充1**对象的属性值可以是任何的数据类型也可以是个**函数**也称之为方法
```javascript
var obj = new Object();
obj.sayName = function () {
console.log('smyhvae');
};
console.log(obj.sayName); //没加括号,就是获取方法
console.log('-----------');
console.log(obj.sayName()); //加了括号,就是调用方法。即:执行函数内容,并执行函数体的内容
```
打印结果
![](http://img.smyhvae.com/20180314_2109.png)
**补充2**对象中的属性值也可以是一个**对象**
举例
```javascript
//创建对象 obj1
var obj1 = new Object();
obj1.test = undefined;
//创建对象 obj2
var obj2 = new Object();
obj2.name = "smyhvae";
//将整个 obj2 对象,设置为 obj1 的属性
obj1.test = obj2;
console.log(obj1.test.name);
```
打印结果为smyhvae
## 对象和数据类型之间的关系
### 数据类型分类
- **基本数据类型值类型**String 字符串Number 数值Boolean 布尔值Null 空值Undefined 未定义
- **引用数据类型引用类型**Object 对象
**基本数据类型**
基本数据类型的值直接保存在**栈内存**值与值之间是独立存在修改一个变量不会影响其他的变量
**对象**
只要不是那五种基本数据类型就全都是对象
如果使用基本数据类型的数据我们所创建的变量都是独立的不能成为一个整体
对象属于一种复合的数据类型在对象中可以保存多个不同数据类型的属性
对象是保存到**堆内存**中的每创建一个新的对象就会在堆内存中开辟出一个新的空间变量保存的是对象的内存地址对象的引用
换而言之对象的值是保存在**堆内存**中的而对象的引用即变量是保存在**栈内存**中的
**如果两个变量保存的是同一个对象引用当一个通过一个变量修改属性时另一个也会受到影响**
上面这句话很重要我们来看看下面的例子
## 传值和传址的区别
### 传值
代码举例
```js
let a = 1;
let b = a;// 将 b 赋值给 a
b = 2; // 修改 b 的值
```
上方代码中当我修改 b 的值之后a 的值并不会发生改变这个大家都知道我们继续往下看
### 传址一个经典的例子
代码举例
```javascript
var obj1 = new Object();
obj1.name = "孙悟空";
var obj2 = obj1; // 将 obj1 的地址赋值给 obj2。从此 obj1 和 obj2 指向了同一个堆内存空间
//修改obj2的name属性
obj2.name = "猪八戒";
```
上面的代码中当我修改 obj2 的name属性后会发现obj1 name 属性也会被修改因为obj1和obj2指向的是堆内存中的同一个地址
这个例子要尤其注意实战开发中很容易忽略
对于引用类型的数据赋值相当于地址拷贝ab指向了同一个堆内存地址所以改了ba也会变本质上ab就是一个东西
如果你打算把引用类型 A 的值赋值给 B让A和B相互不受影响的话可以通过 Object.assign() 来复制对象效果如下
```js
var obj1 = {name: '孙悟空'};
// 复制对象:把 obj1 赋值给 obj3。两者之间互不影响
var obj3 = Object.assign({}, obj1);
```
## 对象的分类
1.内置对象
- 由ES标准中定义的对象在任何的ES的实现中都可以使用
- 比如ObjectMathDateStringArrayNumberBooleanFunction等
2.宿主对象
- 由JS的运行环境提供的对象目前来讲主要指由浏览器提供的对象
- 比如 BOM DOM比如`console``document`
3.自定义对象
- 由开发人员自己创建的对象
通过 new 关键字创建出来的对象实例都是属于对象类型比如ObjectArrayDate等
## 我的公众号
想学习<font color=#0000ff>**代码之外的技能**</font>****id`qianguyihao`
扫一扫你将发现另一个全新的世界而这将是一场美丽的意外
![](http://img.smyhvae.com/2016040102.jpg)