Web/05-JavaScript之ES6语法/08-ES6:字符串、数组、对象的扩展.md
2020-08-23 23:32:42 +08:00

271 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.

## 字符串的扩展
ES6中的字符串扩展用得少而且逻辑相对简单如下
- `includes(str)`判断是否包含指定的字符串
- `startsWith(str)`判断是否以指定字符串开头
- `endsWith(str)`判断是否以指定字符串结尾
- `repeat(count)`重复指定次数
举例如下
```javascript
let str = 'abcdefg';
console.log(str.includes('a'));//true
console.log(str.includes('h'));//false
//startsWith(str) : 判断是否以指定字符串开头
console.log(str.startsWith('a'));//true
console.log(str.startsWith('d'));//false
//endsWith(str) : 判断是否以指定字符串结尾
console.log(str.endsWith('g'));//true
console.log(str.endsWith('d'));//false
//repeat(count) : 重复指定次数a
console.log(str.repeat(5));
```
打印结果
![](http://img.smyhvae.com/20180402_1050.png)
## Number 的扩展
- 二进制与八进制数值表示法: 二进制用`0b`, 八进制用`0o`
举例
```javascript
console.log(0b1010);//10
console.log(0o56);//46
```
- `Number.isFinite(i)`判断是否为有限大的数比如`Infinity`这种无穷大的数返回的就是false
- `Number.isNaN(i)`判断是否为NaN
- `Number.isInteger(i)`判断是否为整数
- `Number.parseInt(str)`将字符串转换为对应的数值
- `Math.trunc(i)`去除小数部分
举例
```javascript
//Number.isFinite(i) : 判断是否是有限大的数
console.log(Number.isFinite(NaN)); //false
console.log(Number.isFinite(5)); //true
console.log(Number.isFinite(Infinity)); //false
//Number.isNaN(i) : 判断是否是NaN
console.log(Number.isNaN(NaN));//true
console.log(Number.isNaN(5));//falsse
//Number.isInteger(i) : 判断是否是整数
console.log(Number.isInteger(5.23));//false
console.log(Number.isInteger(5.0));//true
console.log(Number.isInteger(5));//true
//Number.parseInt(str) : 将字符串转换为对应的数值
console.log(Number.parseInt('123abc'));//123
console.log(Number.parseInt('a123abc'));//NaN
// Math.trunc(i) : 直接去除小数部分
console.log(Math.trunc(13.123));//13
```
## 数组的扩展
> 下面提到的数组的几个方法更详细的内容可以看04-JavaScript基础/17-数组的常见方法.md
### 扩展1Array.from()
```javascript
Array.from(伪数组/可遍历的对象)
```
**作用****伪数组**或可遍历对象转换为**真数组**
### 扩展2Array.of()
```javascript
Array.of(value1, value2, value3)
```
**作用**将一系列值转换成数组
### 扩展3find() findIndex()
**方法1**
```javascript
find(function(item, index, arr){return true})
```
**作用**找出**第一个**满足指定条件返回true的元素
**方法2**
```javascript
findIndex(function(item, index, arr){return true})
```
**作用**找出第一个满足指定条件返回true的元素的index
## 对象的扩展
### 扩展1
```javascript
Object.is(v1, v2)
```
**作用**判断两个数据是否完全相等底层是通过**字符串**来判断的
我们先来看下面这两行代码的打印结果
```javascript
console.log(0 == -0);
console.log(NaN == NaN);
```
打印结果
```
true
false
```
上方代码中第一行代码的打印结果为true这个很好理解第二行代码的打印结果为false因为NaN和任何值都不相等
但是如果换成下面这种方式来比较
```javascript
console.log(Object.is(0, -0));
console.log(Object.is(NaN, NaN));
```
打印结果却是
```
false
true
```
代码解释还是刚刚说的那样`Object.is(v1, v2)`比较的是字符串是否相等
### Object.assign()
Object.assign() 在实战开发中使用到的频率非常高一定要重视
```javascript
Object.assign(目标对象, 源对象1, 源对象2...)
```
**作用** 将源对象的属性追加到目标对象上如果对象里属性名相同会被覆盖
其实可以理解成将多个对象**合并**为一个新的对象
**举例1**对象的属性复制
```javascript
let obj1 = { name: 'smyhvae', age: 26 };
let obj2 = { city: 'shenzhen' };
let obj3 = {};
Object.assign(obj3, obj1, obj2);
console.log(obj3);
```
打印结果
![](http://img.smyhvae.com/20180404_2240.png)
上图显示成功将obj1和obj2的属性复制追加给了obj3如果属性名相同会被覆盖
**举例2**将对象 A 赋值给对象B
```js
const obj1 = { name: 'smyhvae', age: 26 };
const obj2 = Object.assign({}, obj1);
```
注意将对象 A 复制给对象 B不要直接使用 `B = A`而是要使用 Object.assign()至于为何这样做的原因我们在之前的JS基础/对象简介和对象的基本操作里已经讲过
### 扩展3`__proto__`属性
举例
```javascript
let obj1 = {name:'smyhvae'};
let obj2 = {};
obj2.__proto__ = obj1;
console.log(obj1);
console.log(obj2);
console.log(obj2.name);
```
打印结果
![](http://img.smyhvae.com/20180404_2251.png)
上方代码中obj2本身是没有属性的但是通过`__proto__`属性和obj1产生关联于是就可以获得obj1里的属性
```javascript
```