ES6学习笔记(二):引用数据类型
Array
新增方法
1.Array.from()
将类数组(dom对象 或 arguments)或set\map对象转换为数组
2.Array.of()
将一组值转换为数组,例如Array.of(3,5,7,9) => [3,5,7,9]
3.Array.prototype.copyWithin()
数字内部复制
4.数组实例的find()和findIndex()
例如[1,2,3].find(n => n > 2) // 3
5.数组实例的fill()
使用给定的值填充数组
6.数组实例的entries(),keys()和values()
keys() 遍历数组key值
values() 遍历数组value值
entries() 遍历数组key和value值
7.数组实例的includes()
检测数组中是否含有某个值,返回一个布尔值
数组的空位
注意与undefined区分
Function
设置参数默认值
参数变量是默认声明的,所以不能用let或const再次声明。
es5:
function doSomething(x){
x = x || 1;
console.log(x);
}
doSomething() // 1
es6:
function doSomething(x = 1){
console.log(x)
}
doSomething() // 1
arguments.length失真的问题
如果设置了默认值,则length失真
length属性的返回值,等于函数的参数个数减去指定了默认值的参数个数。
rest参数也不会计入length属性。
(function (a) {}).length // 1
(function (a = 5) {}).length // 0
(function (a, b, c = 5) {}).length // 2
rest参数
rest参数是一个数组
function push( ...items) {
console.log(items)
}
push(1, 2, 3); // [1,2,3]
注意,rest参数之后不能再有其他参数(即只能是最后一个参数),否则会报错。
扩展运算符...
它好比rest参数的逆运算,将一个数组转为用逗号分隔的参数序列。
// ES5的写法
Math.max.apply(null, [14, 3, 77])
// ES6的写法
Math.max(...[14, 3, 77])
// 等同于
Math.max(14, 3, 77);
应用:
1.合并数组 [...arr1,...arr2,...arr3]
2.转换字符串为数组 [...'hello] // [ "h", "e", "l", "l", "o" ]
3.实现了Iterator接口的对象转换为数组(注意与Array.from区别)
箭头函数
使用注意点:
1.this指向定义时的对象,非执行时所在的对象
2.不能使用new命令
3.不能使用arguments、super、new.target,可用rest参数
4.不能使用yield命令
var obj = {
id:42,
foo() {
setTimeout(() => {
console.log('id:', this.id);
}, 100);
}
}
var id = 21;
obj.foo()// id: 42
以上例子中如果不用箭头函数,则结果会是id:21,因为this指向的window。
箭头函数里面根本没有自己的this,而是引用外层的this。
// ES6
function foo() {
setTimeout(() => {
console.log('id:', this.id);
}, 100);
}
// ES5
function foo() {
var _this = this;
setTimeout(function () {
console.log('id:', _this.id);
}, 100);
}
函数绑定
1.语法:
func::obj 等价于 func.bind(obj)
2.传参数写法
func::obj(...arguments) 等价于 func.bind(obj,...arguments)
3.省略写法
::obj.func 等价于 obj::obj.func
尾调用和尾递归优化
函数参数逗号尾
Object
对象简写
1.只写属性名
2.属性名表达式(字符串拼接)
var foo = '111';
var bar = {foo};
console.log(bar); // {foo:'111'}
新方法
1.Object.is(obj1,obj2) // 判断两个对象是否等价
2.Object.assign() // 对象合并,类似于jQuery的$.extend()
应用:为对象添加属性、克隆对象、合并多个对象、为属性添加默认值
浅拷贝:如果源对象某个属性是引用数据类型,则目标对象拷贝后得到的是该引用。
注意:拷贝嵌套的对象,如果属性名相同,则会替换该属性的值而非添加
属性的可枚举性
以下操作会忽略enumerable为false的属性
1.for...in
2.Object.keys()
3.JSON.stringify()
4.Object.assign()
ES6规定,所有Class的原型的方法都是不可枚举的。
属性的遍历
(1)for...in // 遍历自身的和继承的属性(不含Symbol)
(2)Object.keys(obj) // 遍历对象自身属性,并将所有属性返回为一个数组(不含继承和Symbol)
(3)Object.getOwnPropertyNames(obj) // 返回一个数组,遍历对象自身的所有属性(不含Symbol,包括不可枚举的)
(4)Object.getOwnPropertySymbols(obj) // 返回一个数组,包含对象自身的所有Symbol属性
(5)Reflect.ownKeys(obj) // 返回一个数组,包含对象自身的所有属性,不管是属性名是Symbol或字符串,也不管是否可枚举。
属性遍历的次序规则:
首先:数值的属性,按照数字排序。
其次:字符串的属性,按照生成时间排序。
最后:所有属性名为Symbol值的属性,按照生成时间排序。
Object.setPrototypeOf(),Object.getPrototypeOf()
Object.values(),Object.entries()
Object.values(): 遍历对象,返回所有属性的值组成的数组
Object.entries(): 返回一个数组,成员是对象自身的(不含继承的)所有可遍历(enumerable)属性的键值对数组。
Object.getOwnPropertyDescriptor和Object.getOwnPropertyDescriptors
ES6学习笔记(二):引用数据类型的更多相关文章
- ES6学习笔记<二>arrow functions 箭头函数、template string、destructuring
接着上一篇的说. arrow functions 箭头函数 => 更便捷的函数声明 document.getElementById("click_1").onclick = ...
- Typescript 学习笔记二:数据类型
中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...
- Java学习笔记二:数据类型II
GitHub代码练习地址:https://github.com/Neo-ML/JavaPractice/blob/master/Intpractice3.java 一 Java中的数据类型 Java ...
- Java学习笔记day03_引用数据类型
1.引用数据类型 步骤: 1. 导包 2. 创建引用类型变量 类型 变量名 = new 类型名(); 3. 使用数据类型的功能 变量名.功能名(); 如Scanner类: import jav ...
- ES6学习笔记二
字符串遍历 var str = 'hello'; for(let s of str){console.log(s += ' ')} //h e l l o 字符串查找:添加了include(str,i ...
- ES6学习笔记二:各种扩展
转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/7242967.html 一:字符串扩展 1:字符串遍历器 for (let char of str) { // ...
- ES6学习笔记(二)——字符串扩展
相信很多人也和我一样,不喜欢这样循规蹈矩的逐条去学习语法,很枯燥乏味.主要是这样学完一遍之后,没过一段时间就忘到九霄云外了.不如实际用到的时候研究它记得牢靠,所以我就整理成笔记,加深记忆的同时便于复习 ...
- python学习笔记(二):python数据类型
上一篇博客写了python的入门和简单流程控制,这次写python的数据类型和各种数据类型的内置方法.一.数据类型是什么鬼?计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各 ...
- ES6学习笔记(二)
Set 和 Map 数据结构 1.set 基本用法 ES6提供了新的数据结构Set,它类似于数组,但是成员的值都是唯一的,没有重复的值 Set本身是一个构造函数,用来生成Set数据结构 const s ...
- es6学习笔记二:生成器 Generators
今天这篇文章让我感到非常的兴奋,接下来我们将一起领略ES6中最具魔力的特性. 为什么说是“最具魔力的”?对于初学者来说,此特性与JS之前已有的特性截然不同,可能会觉得有点晦涩难懂.但是,从某种意义上来 ...
随机推荐
- NRF51822/NRF51802/NRF52810/NRF52811的详解区别
nRF51系列 - 多协议低功耗蓝牙和ANT/ANT+ 和2.4GHz专用系统级芯片 NRF51822-QFAA和NRF51802-QFAA在FLASH RAM的容量没有差别:区别在于:1.接收灵敏度 ...
- CSS中的before和:after伪元素深入理解
1.定义: “伪元素”,顾名思义.就是它创建了一个虚假的元素,并且将其虚假的元素插入到目标元素的内容之前或之后. 2:特点: a.它在实际文档中不改变什么,但是对用户可见,可以通过css控制,源码中看 ...
- 树上三角形 BZOJ3251
分析: 模拟赛T3,其实很水,当时出于某些原因,没有去写这道题... len>46必定有解 为了满足不是三角形,那么斐波那契数列是最优选择,而斐波那契数列的第46项超过了2^31-1,所以超过4 ...
- Ruby知识总结-一般变量+操作符+if+数组和哈希
ruby入门掌握其实很简单,下面对我司主要使用的部分入门做一个简单的归纳总结: 本文的文章结构: 1.变量 2.操作符 3.if~else~end .unless 4.数组(Array) 5.哈希(H ...
- Luogu P4071 [SDOI2016]排列计数
晚上XZTdalao给我推荐了这道数论题.太棒了又可以A一道省选题了 其实这道题也就考一个错排公式+组合数+乘法逆元 我们来一步一步分析 错排公式 通俗的说就是把n个1~n的数排成一个序列A,并使得所 ...
- 蓝牙inquiry流程之HCI_Inquiry_Result_With_RSSI和HCI Extended Inquiry Result处理
首先介绍一下和inquiry的相关的流程. inquiry是从协议栈下发的一个HCI命令.其格式如下: 这里简单介绍下第二个参数,是inquiry的持续时间, 从上图看出 inquiry持续的时间是 ...
- libgdx学习记录17——照相机Camera
照相机在libgdx中的地位举足轻重,贯穿于整个游戏开发过程的始终.一般我们都通过Stage封装而间接使用Camera,同时我们也可以单独使用Camera以完成背景的移动.元素的放大.旋转等操作. C ...
- [CF1009G]Allowed Letters[贪心+霍尔定理]
题意 给你一个长为 \(n\) 的串,字符集为 \(a,b,c,d,e,f\) .你可以将整个串打乱之后重新放置,但是某些位置上有一些限制:必须放某个字符集的字符.问字典序最小的串,如果无解输出 &q ...
- 【ORACLE】oracle数据库用户密码复杂度配置
-- 设置密码复杂度 SQL> @ /u01/app/oracle/product/11.2.0/db_1/rdbms/admin/utlpwdmg.sql -- 测试 SQL> alte ...
- 第一次软件工程作业(One who wants to wear the crown, Bears the crown.)
回顾你过去将近3年的学习经历 1.当初报考的时候,是真正的喜欢计算机这个专业吗? 报考时对于计算机专业只能说不讨厌,也可以认为对其没有任何的感觉. 有一个比我自己还注意我未来的老妈,我的报考只能通过一 ...