JS笔记(1)

来源:互联网 发布:大数据风险管理方法 编辑:程序博客网 时间:2024/06/03 20:22

数组方法总结

1.map

方法会迭代数组中的每一个元素,并根据回调函数来处理每一个元素,最后返回一个新数组。注意,这个方法不会改变原始数组。
var timesFour = oldArray.map(function(val){
return val * 4;
});

2.reduce

数组方法 reduce 用来迭代一个数组,并且把它累积到一个值中。

使用 reduce 方法时,你要传入一个回调函数,这个回调函数的参数是一个 累加器 (比如例子中的 previousVal) 和当前值 (currentVal)。

reduce 方法有一个可选的第二参数,它可以被用来设置累加器的初始值。如果没有在这定义初始值,那么初始值将变成数组中的第一项,而 currentVal 将从数组的第二项开始。

下面的例子使用了 reduce 来让数组中的所有值相减:
`var singleVal = array.reduce(function(previousVal, currentVal) {
return previousVal - currentVal;

3. filter

filter 方法用来迭代一个数组,并且按给出的条件过滤出符合的元素。

filter 方法传入一个回调函数,这个回调函数会携带一个参数,参数为当前迭代的项(我们叫它 val )。

回调函数返回 true 的项会保留在数组中,返回 false 的项会被过滤出数组。

下面的代码示例展示了使用 filter 来移除数组中值等于5的项:
array = array.filter(function(val) {
return val !== 5;
});

注意: 我们忽略了第二参数和第三参数,因为例子中我们只需要第一参数就够了。

4.sort

使用 sort 方法,你可以很容易的按字母顺序或数字顺序对数组中的元素进行排序。

与我们之前用的数组方法仅仅返回一个新数组不同, sort 方法将改变原数组,返回被排序后的数组。

sort 可以把比较函数作为参数传入。比较函数有返回值,当 a 小于 b,返回一个负数;当 a 大于 b ,返回一个正数;相等时返回0。

如果没有传入比较函数,它将把值全部转成字符串,并按照字母顺序进行排序。

下面的例子将展示 sort 的使用,传入的比较函数把元素按照从小到大的顺序进行排列:var array = [1, 12, 21, 2];
array.sort(function(a, b) {
return a - b;

5.reverse

你可以使用 reverse 方法来翻转数组。
var myArray = [1, 2, 3];
myArray.reverse();

6.concat

concat 方法可以用来把两个数组的内容合并到一个数组中。

concat 方法的参数应该是一个数组。参数中的数组会拼接在原数组的后面,并作为一个新数组返回。

下面是一个拼接数组的例子,用concat 把 otherArray 拼接在 oldArray 的后面:

newArray = oldArray.concat(otherArray);

使用 .concat() 将 concatMe 拼接到 oldArray 后面,并且赋值给 newArray。

7. split

你可以使用 split 方法按指定分隔符将字符串分割为数组。

你要给 split 方法传递一个参数,这个参数将会作为一个分隔符。

下面的例子展示了 split 方法的使用,按照 s 字母进行分割:

var array = string.split('s');

使用 split 方法来把字符串 string 分割为数组 array。

8. join

我们还可以使用 join 方法来把数组转换成字符串,里面的每一个元素可以用你指定的连接符来连接起来,这个连接符就是你要传入的参数。

下面展示了使用 join 来将数组中的每一项放入字符串,并用 and 进行连接:

var veggies = ["Celery", "Radish", "Carrot", "Potato"];
var salad = veggies.join(" and ");
console.log(salad); // "Celery and Radish and Carrot and Potato"

使用 join 方法,连接符为’ ‘把数组 joinMe 转化成字符串 joinedString.

9. Array.prototype.slice()

slice()表示一个从开始结束选择的数组的一部分浅拷贝到一个新的数组对象。不改变原始数组。
语法:

arr.slice()arr.slice(begin)arr.slice(begin, end)

由于字符串与数组共通性,具体的参数使用方法与字符串的slice使用方法是共通的:

slice(begin, end)参数使用方法

注意:下面的例题输出下标为1到3的数组元素,但是包括1不包括3。

let a = [''zero', 'one', 'two', 'three'];let sliced = a.slice(1,3); console.log(a);  //[''zero', 'one', 'two', 'three']console.log(sliced); //['one', 'two']
  • 如果该元素是个对象引用(不是实际对象),slice会拷贝这个对象引用到新的数组里。两个对象引用都引用了同一个对象。如果被引用的对象发生改变,则新的和原来的数组中的这个元素也会发生改变。
  • 对于字符串、数字及布尔值来说(不是String、Number或者Boolean对象),slice会拷贝这些值到新的数组里。在别的数组里修改这些字符串或数字或是布尔值,将不会影响另一个数组。
原创粉丝点击