码迷,mamicode.com
首页 > 编程语言 > 详细

ES6中的函数和数组补漏

时间:2017-07-05 23:42:32      阅读:199      评论:0      收藏:0      [点我收藏+]

标签:弊端   als   也有   bsp   nbsp   存在   处理   解决   开发   

对象的函数解构

我们在前后端分离时,后端经常返回来JSON格式的数据,前端的美好愿望是直接把这个JSON格式数据当作参数,传递到函数内部进行处理。ES6就为我们提供了这样的解构赋值。
let json = {
    a:‘xzblogs‘,
    b:‘小智‘
}
function fun({a,b=‘如果没有b用这个替补‘}){
    console.log(a,b);
}
fun(json);
是不是感觉方便了很多,我们再也不用一个个传递参数了。

数组的函数解构

函数能解构JSON,那解构我们的数组就更不在话下了,我们看下边的代码。我们声明一个数组,然后写一个方法,最后用…进行解构赋值。
let arr = [‘xzblogs‘,‘小智‘,‘zachary‘];
function fun(a,b,c){
    console.log(a,b,c);
}
fun(...arr);

in的用法

in是用来判断对象或者数组中是否存在某个值的。我们先来看一下用in如何判断对象里是否有某个值。

对象判断

let obj={
    a:‘xzblogs‘,
    b:‘小智‘
}
console.log(‘a‘ in obj);  //true

数组判断

先来看一下ES5判断的弊端,以前会使用length属性进行判断,为0表示没有数组元素。但是这并不准确,或者说真实开发中有弊端。
let arr=[,,,,,];
console.log(arr.length); //5
上边的代码输出了5,但是数组中其实全是空值,这就是一个坑啊。那用ES6的in就可以解决这个问题。
let arr=[,,,,,];
console.log(0 in arr); //false
 
let arr1=[‘xz‘,‘小智‘];
console.log(0 in arr1);  // true
注意:这里的0指的是数组下标位置是否为空。

数组的遍历方法

1.forEach

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
arr.forEach((val,index)=>console.log(index,val));
forEach循环的特点是会自动省略为空的数组元素,相当于直接给我们筛空了。当是有时候也会给我们帮倒忙。

2.filter

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
arr.filter(x=>console.log(x));
这种方法在Vue实战里我讲过,他其实也有循环的功能,这里我们在复习一遍。

3.some

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
arr.some(x=>console.log(x));

4.map

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
console.log(arr.map(x=>‘web‘));
map在这里起到一个替换的作用,这个我们后续课程会详细讲解。

数组转换字符串

在开发中我们经常会碰到把数组输出成字符串的形式,我们今天学两种方法,你要注意两种方法的区别。

join()方法

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
console.log(arr.join(‘|‘));
join()方法就是在数组元素中间,加了一些间隔,开发中很有用处。

toString()方法

let arr=[‘xzblogs‘,‘小智‘,‘zachary‘];
console.log(arr.toString());
转换时只是是用逗号隔开了。

 

 

ES6中的函数和数组补漏

标签:弊端   als   也有   bsp   nbsp   存在   处理   解决   开发   

原文地址:http://www.cnblogs.com/model-zachary/p/7123932.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!