luffa

本文将记录一些Javascript常用的数组、字符串的操作,方便项目开发以及JS算法的编写。

 

数组(Array)

1.push():

向数组尾部添加一个或多个元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组

var arr = [1,2,3];
console.log(arr);        //  [1, 2, 3]
var b = arr.push(4);  
console.log(b);          //  4   //表示当前数组长度
console.log(arr);        // [1, 2, 3, 4]

2.pop():

删除数组的最后一个元素,并返回该元素。注意,该方法会改变原数组

var arr = [1,2,3];
console.log(arr);                // [1,2,3]
arr.pop();
console.log( arr.pop() );  // [3]  //返回删除的元素
console.log(arr);                // [1,2]

3.unshift():

在数组的第一个位置添加元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组

var arr = [\'a\', \'b\', \'c\'];
arr.unshift(\'x\');        // 4
console.log(arr);        // [\'x\', \'a\', \'b\', \'c\']

4.shift():

删除数组的第一个元素,并返回该元素。注意,该方法会改变原数组

var arr = [\'a\', \'b\', \'c\'];
arr.shift()         // \'a\'
console.log(arr)     // [\'b\', \'c\']  

注意shift()方法还可以遍历并清空一个数组。

var list = [1, 2, 3, 4, 5, 6];
var item;

while (item = list.shift()) {
  console.log(item);
}

console.log(list);     // []

5.indexOf():

返回指定元素在数组中出现的位置,如果没有出现则返回-1。

var arr = [\'a\', \'b\', \'c\'];

arr.indexOf(\'b\') // 1
arr.indexOf(\'y\') // -1

indexOf方法还可以接受第二个参数,表示搜索的开始位置。

[\'a\', \'b\', \'c\'].indexOf(\'a\', 1)     // -1

上面代码从1号位置开始搜索字符a,结果为-1,表示没有搜索到。  

6.join():

以参数作为分隔符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分隔。

var arr = [1, 2, 3, 4];

arr.join(\' \')     // \'1 2 3 4\'
arr.join(\' | \')     // "1 | 2 | 3 | 4"
arr.join()     // "1,2,3,4"

7.concat():

用于多个数组的合并。它将新数组的成员,添加到原数组的尾部,然后返回一个新数组,原数组不变

var arr = [1,2,3];
var b = arr.concat([4,5,6]);
console.log(b);        //[1,2,3,4,5,6]

8.reverse():

用于颠倒数组中元素的顺序,返回改变后的数组。注意,该方法将改变原数组

var arr = [\'a\', \'b\', \'c\'];

arr.reverse() // ["c", "b", "a"]
console.log(arr) // ["c", "b", "a"]

9.slice():
用于截取原数组的一部分,返回一个新数组,原数组不变

slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。

var arr = [\'a\', \'b\', \'c\'];

arr.slice(0)         // ["a", "b", "c"]
arr.slice(1)         // ["b", "c"]
arr.slice(1, 2)     // ["b"]
arr.slice(2, 6)     // ["c"]
arr.slice()           // ["a", "b", "c"]    无参数返回原数组

arr.slice(-2)          // ["b", "c"]    参数是负数,则表示倒数计算的位置
arr.slice(-2, -1)     // ["b"]

10.splice():

删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组

splice(start,delNum,addElement1,addElement2,...)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。

var arr = [\'a\', \'b\', \'c\', \'d\', \'e\', \'f\'];
arr.splice(4, 2)     // ["e", "f"]  从原数组4号位置,删除了两个数组成员
console.log(arr)     // ["a", "b", "c", "d"]

var arr = [\'a\', \'b\', \'c\', \'d\', \'e\', \'f\'];
arr.splice(4, 2, 1, 2)     // ["e", "f"]  原数组4号位置,删除了两个数组成员,又插入了两个新成员
console.log(arr)         // ["a", "b", "c", "d", 1, 2]

var arr = [\'a\', \'b\', \'c\', \'d\', \'e\', \'f\'];
arr.splice(-4, 2)     // ["c", "d"]    起始位置如果是负数,就表示从倒数位置开始删除

var arr = [1, 1, 1];
arr.splice(1, 0, 2)     // []    如果只插入元素,第二个参数可以设为0
conlose.log(arr)     // [1, 2, 1, 1]

var arr = [1, 2, 3, 4];
arr.splice(2)     // [3, 4] 如果只有第一个参数,等同于将原数组在指定位置拆分成两个数组
console.log(arr)     // [1, 2]

11.sort():

对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变

[\'d\', \'c\', \'b\', \'a\'].sort()
// [\'a\', \'b\', \'c\', \'d\']

[4, 3, 2, 1].sort()
// [1, 2, 3, 4]

[11, 101].sort()
// [101, 11]

[10111, 1101, 111].sort()
// [10111, 1101, 111]

上面代码的最后两个例子,需要特殊注意。sort方法不是按照大小排序,而是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进行比较,所以101排在11的前面。

如果想让sort方法按照自定义方式排序,可以传入一个函数作为参数,表示按照自定义方法进行排序。该函数本身又接受两个参数,表示进行比较的两个元素。如果返回值大于0,表示第一个元素排在第二个元素后面;其他情况下,都是第一个元素排在第二个元素前面。

var arr = [10111, 1101, 111];
arr.sort(function (a, b) {
  return a - b;
})
// [111, 1101, 10111]

var arr1 = [
              { name: "张三", age: 30 },
              { name: "李四", age: 24 },
              { name: "王五", age: 28 }
           ]

arr1.sort(function (o1, o2) {
  return o1.age - o2.age;
}) 
// [
//   { name: "李四", age: 24 },
//   { name: "王五", age: 28 },
//   { name: "张三", age: 30 }
// ]

12.map():

对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组

var numbers = [1, 2, 3];

numbers.map(function (n) {
  return n + 1;
});
// [2, 3, 4]

numbers
// [1, 2, 3]

上面代码中,numbers数组的所有成员都加上1,组成一个新数组返回,原数组没有变化。

11.filter():

参数是一个函数,所有数组成员依次执行该函数,返回结果为true的成员组成一个新数组返回。该方法不会改变原数组

var arr = [1, 2, 3, 4, 5]
arr.filter(function (elem) {
  return (elem > 3);
})
// [4, 5]

  

分类:

技术点:

相关文章:

  • 2021-12-09
  • 2021-11-13
  • 2021-11-13
  • 2021-11-13
  • 2021-09-30
  • 2021-11-01
  • 2021-11-29
猜你喜欢
  • 2022-01-02
  • 2021-11-13
  • 2018-12-18
  • 2021-11-13
  • 2019-02-21
  • 2021-11-13
  • 2021-11-13
相关资源
相似解决方案