js字符串的字典序_JS数组、字符串常⽤⽅法数组:
1.push(): 向数组尾部添加⼀个或多个元素,并返回添加新元素后的数组长度。注意,该⽅法会改变原数组。
1 var arr = [1,2,3];
2 console.log(arr); //[1, 2, 3]
3 var b = arr.push(4);
4 console.log(b); //4 //表⽰当前数组长度
5 console.log(arr); //[1, 2, 3, 4]
pop(): 删除数组的最后⼀个元素,并返回该元素。注意,该⽅法会改变原数组。
1 var arr = [1,2,3];
2 console.log(arr); //[1,2,3]
3 arr.pop();
4 console.log( arr.pop() );  //[3]  //返回删除的元素
5 console.log(arr); //[1,2]
2.unshift():在数组的第⼀个位置添加元素,并返回添加新元素后的数组长度。注意,该⽅法会改变原数组。
1 var arr = ['a', 'b', 'c'];
2 arr.unshift('x'); //4
3 console.log(arr); //['x', 'a', 'b', 'c']
shift():删除数组的第⼀个元素,并返回该元素。注意,该⽅法会改变原数组。
1 var arr = ['a', 'b', 'c'];
2 arr.shift() //'a'
3 console.log(arr) //['b', 'c']
shift()⽅法还可以遍历并清空⼀个数组。
1 var list = [1, 2, 3, 4, 5, 6];
2 varitem;3
4 while (item =list.shift()) {
5 console.log(item);
6 }7
8 console.log(list); //[]
3.valueOf():返回数组的本⾝。
1 var arr = [1, 2, 3];
2 arr.valueOf() //[1, 2, 3]
indexOf():返回指定元素在数组中出现的位置,如果没有出现则返回-1。
1 var arr = ['a', 'b', 'c'];2
3 arr.indexOf('b') //1
4 arr.indexOf('y') //-1
indexOf⽅法还可以接受第⼆个参数,表⽰搜索的开始位置。
1 ['a', 'b', 'c'].indexOf('a', 1) //-1
上⾯代码从1号位置开始搜索字符a,结果为-1,表⽰没有搜索到。
toString():返回数组的字符串形式。
1 var arr = [1, 2, 3];
String() //"1,2,3"
3
4 var arr = [1, 2, 3, [4, 5, 6]];
String() //"1,2,3,4,5,6"
4.join():以参数作为分隔符,将所有数组成员组成⼀个字符串返回。如果不提供参数,默认⽤逗号分隔。
1 var arr = [1, 2, 3, 4];2
3 arr.join(' ') //'1 2 3 4'
4 arr.join(' | ') //"1 | 2 | 3 | 4"
5 arr.join() //"1,2,3,4"
1 var arr = [1,2,3];
2 var b = at([4,5,6]);
3 console.log(b); //[1,2,3,4,5,6]
1 var arr = ['a', 'b', 'c'];2
verse() //["c", "b", "a"]
4 console.log(arr) //["c", "b", "a"]
7.slice():⽤于截取原数组的⼀部分,返回⼀个新数组,原数组不变。
slice(start,end)它的第⼀个参数为起始位置(从0开始),第⼆个参数为终⽌位置(但该位置的元素本⾝不包括在内)。如果省略第⼆个参数,则⼀直返回到原数组的最后⼀个成员。
1 var arr = ['a', 'b', 'c'];2
3 arr.slice(0) //["a", "b", "c"]
4 arr.slice(1) //["b", "c"]
5 arr.slice(1, 2) //["b"]
6 arr.slice(2, 6) //["c"]
7 arr.slice() //["a", "b", "c"] ⽆参数返回原数组
8
9 arr.slice(-2) //["b", "c"] 参数是负数,则表⽰倒数计算的位置
10 arr.slice(-2, -1) //["b"]
8.splice():删除原数组的⼀部分成员,并可以在被删除的位置添加⼊新的数组成员,返回值是被删除的元素。注意,该⽅法会改变原数组。
splice(start,delNum,addElement1,addElement2,...)第⼀个参数是删除的起始位置,第⼆个参数是被删除的元素个数。如果后⾯还有更多的参数,则表⽰这些就是要被插⼊数组的新元素。
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(4, 2) //["e", "f"]  从原数组4号位置,删除了两个数组成员
3 console.log(arr) //["a", "b", "c", "d"]
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(4, 2, 1, 2) //["e", "f"]  原数组4号位置,删除了两个数组成员,⼜插⼊了两个新成员
3 console.log(arr) //["a", "b", "c", "d", 1, 2]
1 var arr = ['a', 'b', 'c', 'd', 'e', 'f'];
2 arr.splice(-4, 2) //["c", "d"] 起始位置如果是负数,就表⽰从倒数位置开始删除
1 var arr = [1, 1, 1];2
3 arr.splice(1, 0, 2) //[] 如果只插⼊元素,第⼆个参数可以设为0
4 conlose.log(arr) //[1, 2, 1, 1]
1 var arr = [1, 2, 3, 4];
2 arr.splice(2) //[3, 4] 如果只有第⼀个参数,等同于将原数组在指定位置拆分成两个数组
3 console.log(arr) //[1, 2]
9.sort():对数组成员进⾏排序,默认是按照字典顺序排序。排序后,原数组将被改变。
1 ['d', 'c', 'b', 'a'].sort()
2 //['a', 'b', 'c', 'd']
3
4 [4, 3, 2, 1].sort()
5 //[1, 2, 3, 4]
6
7 [11, 101].sort()8 //[101, 11]
9
10 [10111, 1101, 111].sort()11 //[10111, 1101, 111]
上⾯代码的最后两个例⼦,需要特殊注意。sort⽅法不是按照⼤⼩排序,⽽是按照对应字符串的字典顺序排序。也就是说,数值会被先转成字符串,再按照字典顺序进⾏⽐较,所以101排在11的前⾯。
如果想让sort⽅法按照⾃定义⽅式排序,可以传⼊⼀个函数作为参数,表⽰按照⾃定义⽅法进⾏排序。该函数本⾝⼜接受两个参数,表⽰进⾏⽐较的两个元素。如果返回值⼤于0,表⽰第⼀个元素排在第⼆
个元素后⾯;其他情况下,都是第⼀个元素排在第⼆个元素前⾯。
1 var arr = [10111, 1101, 111];
2 arr.sort(function(a, b) {
3 return a -b;
4 })
5 //[111, 1101, 10111]
6
7 var arr1 =[8 { name: "张三", age: 30},9 { name: "李四", age: 24},10 { name: "王五", age: 28}11 ]12
13 arr1.sort(function(o1, o2) {14 return o1.age -o2.age;15 })16 //[
17 //{ name: "李四", age: 24 },
18 //{ name: "王五", age: 28 },
19 //{ name: "张三", age: 30 }
20 //]
10.map():对数组的所有成员依次调⽤⼀个函数,根据函数结果返回⼀个新数组。
1 var numbers = [1, 2, 3];2
3 numbers.map(function(n) {
4 return n + 1;
5 });
js合并两个数组6 //[2, 3, 4]
7
8 numbers9 //[1, 2, 3]
上⾯代码中,numbers数组的所有成员都加上1,组成⼀个新数组返回,原数组没有变化。
11.filter():参数是⼀个函数,所有数组成员依次执⾏该函数,返回结果为true的成员组成⼀个新数组返回。该⽅法不会改变原数组。
1 var arr = [1, 2, 3, 4, 5]
2 arr.filter(function(elem) {
3 return (elem > 3);
4 })
5 //[4, 5]

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。