一、let和const
var:存在变量提升,可以重复声明,不支持块级作用域,不能定义常量
let:只在代码块内有效,必须先声明再使用(不能提升)
const:声明一个只读的常量(常量指向的内存地址不变),只在代码块内有效。常量对象内的属性可以变
二、变量的解构赋值
ES6
允许按照⼀定模式,从数组和对象中提取值,对变量进⾏赋值
let
[
x1
,[[
y1
],
z1
]]
=
[
10
,[[
20
],
30
]];
//
嵌套数组
let
[ , ,
z
]
=
[
"one"
,
"two"
,
"three"
];
console
.
log
(
z
);
//three
//
其中
...
为
ES6
的扩展运算符,即
d
加上
...
可以接收多个值
let
[
a
,
...
d
]
=
[
1
,
2
,
3
,
4
];
console
.
log
(
a
);
// 1
console
.
log
(
d
);
// [2, 3, 4]
let
[
x
,
y
=
'b'
]
=
[
'a'
];
// x='a', y='b' //默认值
对象的解构赋值:
要求变量必须与属性同名
let
{
age
,
name
}
=
{
name
:
'
张三
'
,
age
:
20
};
//
如果变量名与属性名不⼀致,必须写成下⾯这样
let
{
email
:
em
,
password
:
ps
}
=
{
email
:
'zs@163.com'
,
password
:
'123456'
};
//
如上代码
email
和
password
都是匹配的模式,
em
才是变量。真正被赋值的是变量
em
,⽽不是模式
email
类似数组的对象都有⼀个
length属性,因此还可以对这个属性解构赋值。
let
{
length
:
len
}
=
'hello'
;
console
.
log
(
len
);
// 5
用途:
1、交换变量的值
let
x
=
1
;
let
y
=
2
;
[
x
,
y
]
=
[
y
,
x
];
`
2、
从函数返回多个值
//
返回⼀个数组
function
example1
() {
return
[
1
,
2
,
3
];
}
let
[
a
,
b
,
c
]
=
example1
();
//
返回⼀个对象
function
example2
() {
return
{
foo
:
1
,
bar
:
2
};
}
let
{
foo
,
bar
}
=
example2
();
3、函数参数的定义
//
参数是⼀组有次序的值
function
f
([
x
,
y
,
z
]) {
...
}
f
([
1
,
2
,
3
]);
//
参数是⼀组⽆次序的值
function
f
({
x
,
y
,
z
}) {
...
}
f
({
z
:
3
,
y
:
2
,
x
:
1
});
4、提取json的值
//
解构赋值对提取
JSON
对象中的数据,尤其有⽤。
let
jsonData
=
{
id
:
42
,
status
:
"OK"
,
data
: [
867
,
5309
]
};
let
{
id
,
status
,
data
:
number
}
=
jsonData
;
console
.
log
(
id
,
status
,
number
);
// 42, "OK", [867, 5309]
三、函数的扩展
1、函数的默认值
function
add
(
x
=
0
,
y
=
0
){
return
x
+
y
;
}
console
.
log
(
add
());
//0
console
.
log
(
add
(
10
));
//10
2、箭头函数
(
=>
)
var
sum
=
(
num1
,
num2
)
=>
{
return
num1
+
num2
; }
由于⼤括号被解释为代码块,所以如果箭头函数直接返回⼀个对象,必须在对象外⾯加上括号,否
则会报错。
let
getTempItem
=
id
=>
({
id
:
id
,
name
:
"Temp"
});
箭头函数有⼏个使⽤注意点。
(1
)函数体内的
this
对象,就是定义时所在的对象,⽽不是使⽤时所在的对象。
(2
)不可以当作构造函数,也就是说,不可以使⽤
new
命令,否则会抛出⼀个错误。
(3
)当你真的需要
this的时候,如为对象添加普通⽅法或事件绑定回调函数使⽤箭头函数,可能获取不到
this
。
(4
)不可以使⽤
arguments
对象,该对象在函数体内不存在。
上⾯四点中,第⼀点尤其值得注意。
this
对象的指向是可变的,但是在箭头函数中,它是固定的。
数组的扩展:
遍历:
for(普通for循环)
for...in(会遍历其他非数字属性)
for...of(不会遍历非数字属性,支持break和continue)
a.forEach(使用回调函数遍历)
//
数组对象
entries()
⽅法返回⼀个数组的迭代对象,该对象包含数组的键值对
(key/value)
。
//1.
使⽤
for...of
遍历数组:
let
a
=
[
'zhangsan'
,
'lisi'
,
'wangwu'
];
for
(
let
[
k
,
v
]
of
a
.
entries
()){
console
.
log
(
k
,
v
);
}
//0 "zhangsan"
//1 "lisi"
//1 "lisi"
Array.from()
<!DOCTYPE html>
<html
lang
=
"en"
>
<head>
<meta
charset
=
"UTF-8"
>
<title>
Array.from()
使⽤实例
</title>
</head>
<body>
<ul>
<li>
zhangsan
</li>
<li>
lisi
</li>
<li>
wangwu
</li>
</ul>
<script
type
=
"text/javascript"
>
//获取上⾯的li
节点对象列表
let
nlists
=
document
.
querySelectorAll
(
"li"
);
console
.
log
(
nlists
);
//NodeList(3) [li, li, li]
//将NodeList列表对象转成数组,并解析出每个元素之间的内容。
const
alist
=
Array
.
from
(
nlists
,
li
=>
li
.
textContent
);
console
.
log
(
alist
);
// ["zhangsan", "lisi", "wangwu"]
</script>
</body>
</html>
Array.of()
console
.
log
(
Array
.
of
(
1
,
2
,
3
));
//[1,2,3]
创建⼀个值为
1
,
2
,
3
的数组
数组实例的 find() 和 findIndex()
let
s2
=
data
.
find
(
v
=>
v
[
'name'
]
==
'lisi'
);
console
.
log
(
s2
);
//{name: "lisi", age: 25, sex: "woman"}
let
s4
=
data
.
findIndex
(
v
=>
v
[
'name'
]
==
'lisi'
);
console
.
log
(
s4
);
//1
数组实例的 some() 和 every()
every
()和
some
()⽬的:确定数组的所有成员是否满⾜指定的测试
.
some()⽅法 只要其中⼀个为
true
就会返回
true
。
every()⽅法必须所有都返回
true
才会返回
true
,哪怕有⼀个
false
,就会返回
false
。
即:
every:
⼀假即假;
some:
⼀真即真。
![](https://i-blog.csdnimg.cn/blog_migrate/4e6fd1d31f757dd1db5f9bf33a6d1e8d.png)
数组实例的 .fill()
fill()
函数,使⽤指定的元素替换原数组内容,会改变原来的数组。
语法结构:
arr.fill(value[, start[, end]])
value:替换值。
start:替换起始位置(数组的下标),可以省略。
end:替换结束位置(数组的下标),如果省略不写就默认为数组结束