首页
技术小册
AIGC
面试刷题
技术文章
MAGENTO
云计算
视频课程
源码下载
PDF书籍
「涨薪秘籍」
登录
注册
ES5和ES6的介绍
ES5中的严格模式
ES5中的一些扩展
ES6:变量 let、const 和块级作用域
ES6:变量的解构赋值
ES6:箭头函数
剩余参数和扩展运算符
字符串、数组、对象的扩展
内置对象扩展:Set数据结构
Symbol
服务器分类及PHP入门
单线程和异步
Ajax入门和发送http请求
Ajax传输json和XML
同源和跨域
Promise入门详解
Promise的链式调用
Promise的静态方法
宏任务和微任务
Promise应用举例
Async Await函数详解
当前位置:
首页>>
技术小册>>
Javascript-ES6与异步编程
小册名称:Javascript-ES6与异步编程
## 字符串的扩展 > 下面提到的字符串的几个方法,更详细的内容,可以看《04-JavaScript 基础/内置对象 String:字符串的常见方法.md》。 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 基础/数组的常见方法.md》。 - Array.from() - find() - findIndex() ## 对象的扩展 ### 扩展 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)); ``` 打印结果却是: ```bash false true ``` 代码解释:还是刚刚说的那样,`Object.is(v1, v2)`比较的是字符串是否相等。 ### Object.assign() Object.assign() 在实战开发中,使用到的频率非常高,一定要重视。关于它的内容,详见《04-JavaScript 基础/浅拷贝和深拷贝.md》。 ### 扩展 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 里的属性。
上一篇:
剩余参数和扩展运算符
下一篇:
内置对象扩展:Set数据结构
该分类下的相关小册推荐:
Javascript重点难点实例精讲(一)
剑指javascript
JavaScript面试指南
Node.js 开发实战
深入学习前端重构知识体系
npm script实战构建前端工作流
剑指javascript-ES6
Javascript编程指南
javascript设计模式原理与实战
KnockoutJS入门指南
WebSocket入门与案例实战
编程入门课:Javascript从入门到实战