字符串:

1、concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串。 

2、indexOf() – 返回字符串中一个子串第一处出现的索引。如果没有匹配项,返回 -1 。 

3、charAt() – 返回指定位置的字符。 

4、lastIndexOf() – 返回字符串中一个子串最后一处出现的索引,如果没有匹配项,返回 -1 。 

5、match() – 检查一个字符串是否匹配一个正则表达式。 

6、substring() – 返回字符串的一个子串。传入参数是起始位置和结束位置。 

7、replace() – 用来查找匹配一个正则表达式的字符串,然后使用新字符串代替匹配的字符串。 

8、search() – 执行一个正则表达式匹配查找。如果查找成功,返回字符串中匹配的索引值。否则返回 -1 。 

9、slice() – 提取字符串的一部分,并返回一个新字符串。 

10、split() – 通过将字符串划分成子串,将一个字符串做成一个字符串数组。 

11、length – 返回字符串的长度,所谓字符串的长度是指其包含的字符的个数。 

12、toLowerCase() – 将整个字符串转成小写字母。 

13、toUpperCase() – 将整个字符串转成大写字母。

数组:

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 var item;
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];
2 arr.toString() // "1,2,3"
3
4 var arr = [1, 2, 3, [4, 5, 6]];
5 arr.toString() // "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"

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

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

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

1 var arr = ['a', 'b', 'c'];
2
3 arr.reverse() // ["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 });
6 // [2, 3, 4]
7
8 numbers
9 // [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]

Js数组和字符串常用方法的更多相关文章

  1. js数组,字符串常用方法汇总(面试必备)

    字符串: 1.concat() – 将两个或多个字符的文本组合起来,返回一个新的字符串.  2.indexOf() – 返回字符串中一个子串第一处出现的索引.如果没有匹配项,返回 -1 .  3.ch ...

  2. js数组、字符串常用方法

    数组方面 push:向数组尾部增加内容,返回的是新数组的长度. var arr = [1,2,3]; console.log(arr); var b = arr.push(4); console.lo ...

  3. js实用篇之数组、字符串常用方法

    常常在开发中,会使用到很多js数组和字符串的处理方法,这里列举一些我常用到的一些,方便大家参考使用. 数组方面 push:向数组尾部增加内容,返回的是新数组的长度. var arr = [1,2,3] ...

  4. js数组和字符串去重复几种方法

    js数组去重复几种方法 第一种:也是最笨的吧. Array.prototype.unique1 = function () { var r = new Array(); label:for(var i ...

  5. js数组与字符串的相互转换方法

    一.数组转字符串 需要将数组元素用某个字符连接成字符串,示例代码如下: var a, b; a = new Array(0,1,2,3,4); b = a.join("-"); 二 ...

  6. js 数组与字符串的相互转化

    数组转字符串:join() 字符串转数组:split('')

  7. js数组与字符串之间的相互转换

    一.数组转字符串 需要将数组元素用某个字符连接成字符串,示例代码如下 <!doctype html> <html> <head> <meta charset= ...

  8. (转)js数组与字符串的相互转换方法

    一.数组转字符串 需要将数组元素用某个字符连接成字符串,示例代码如下: var a, b; a = new Array(0,1,2,3,4); b = a.join("-"); 二 ...

  9. JavaScript数组与字符串常用方法总结

    先来一段代码引子: var str='hello world'; alert(str.charAt());//通过下标查找值: alert(str.indexOf());//通过值查找字符串下标:没有 ...

随机推荐

  1. 菜鸟vimer成长记——第2.4章、cmd-line模式

    cmd-line模式又有3个类型:Ex 命令(ex commands).查找模式(Search patterns).Filter 命令(Filter commands).本文主要重点的是Ex 命令和S ...

  2. 13-调试Dockerfile

    包括 Dockerfile 在内的任何脚本和程序都会出错.有错并不可怕,但必须有办法排查,所以本节讨论如何 debug Dockerfile. 先回顾一下通过 Dockerfile 构建镜像的过程: ...

  3. 1、AutoCAD ObjectARX开发版本对照表

    ObjectARX开发版本对照表 序号 CAD版本 版本号 二进制兼容 .net框架 ObjectARX开发环境 VC版本号 MAC OS平台 WINDOWS平台 VC版本 _MSC_VER 1 R1 ...

  4. hover时显示可跟随鼠标移动的浮动框,运用函数节流与去抖进行优化

    在很多笔试面试题中总能看到js函数去抖和函数节流,看过很多关于这两者的讨论,最近终于在一个需求中使用了函数去抖(debounce)和函数节流(throttle). 需要完成的效果是,鼠标在表格的单元格 ...

  5. C#如何在各类控件中输入\输出数据

    文本框:TextBox Text - 按钮文字 TextBox.text=""; s=TextBox.text; 单选按钮+复选按钮 RadioButton,CheckBox Te ...

  6. 机器学习算法 --- SVM (Support Vector Machine)

    一.SVM的简介 SVM(Support Vector Machine,中文名:支持向量机),是一种非常常用的机器学习分类算法,也是在传统机器学习(在以神经网络为主的深度学习出现以前)中一种非常牛X的 ...

  7. HTML和JS自解码机制

    1.HTML 如果用户的输入被嵌入到HTML代码中,会进行HTML解码 解码方式包括: 1.HTML实体编码: 假定下面onclick后面的内容是可控的 点击按钮 2.进制编码: 点击按钮 2.JS ...

  8. python正则表达式,以及应用[下载图片]

    regular expresion由一系列特定字符及其组合成的字符串,用来对目标字符串进行过滤操作.. re相关知识点 python正则表达式库为re,用import re导入,在然后用re.comp ...

  9. 2017年第八届蓝桥杯【C++省赛B组】

    1.标题: 购物单 小明刚刚找到工作,老板人很好,只是老板夫人很爱购物.老板忙的时候经常让小明帮忙到商场代为购物.小明很厌烦,但又不好推辞. 这不,XX大促销又来了!老板夫人开出了长长的购物单,都是有 ...

  10. Teamwork#3,Week5,Scrum Meeting 11.20

    到目前为止,第一轮迭代已经基本完成.由于时间问题,多店比较的高级功能要放到第二轮迭代实现. 大部分任务已经完成,在alpha版本发布之前我们剩余需要解决的问题有两个: 服务器.校园网服务器不能满足我们 ...