js数组API和字符串API汇总

一、数组API

1. 连接:arr.join(“连接符”)

用连接符把数组里面的元素连接成字符串。arr.join(“”)能无缝连接。

2. 拼接:arr.concat(“a”,”b”,arr1)

  • 不会修改原数组,返回新数组。
  • concat方法中的数组会被打散为单个元素再拼接。

3. 截取:arr.slice(start[,end])

  • 不会修改原数组,返回新的子数组。
  • 含头不含尾。
  • 省略第二个参数表示从start位置开始一直截取到末尾。
  • 支持负数,表示倒数第几个。

4. 删除、插入、替换:arr.splice(start,n[,value1,value2…])

  • 直接修改原数组。
  • 返回所有被删除元素组成的子数组。
  • 如果是插入,删除了0个数,那么从start位置开始以及之后的元素会被顺移。

5. 翻转数组:arr.reverse()

直接修改原数组。

6. 数组排序:arr.sort()

  • 直接修改原数组。
  • 默认按照数组元素第一位的ASCII码从小到大排列。
  • 可以设置下列的比较器函数来控制升序,降序或者打乱。
  • arr.sort(function(a,b){return a-b;}); 升序(只限数组中是数字或者数字字符串)。
  • arr.sort(function(a,b){return b-a;}); 降序(只限数组中是数字或者数字字符串)。
  • arr.sort(function(){return Math.random()>.5 ? 1 : -1;});随机打乱数组(数组中可以是任何数据类型)

7. 查找:arr.indexOf(value[,from])或arr.lastIndexOf(value[,from])

返回value在数组中的位置,没有找到返回-1。

8. 是否有符合的:arr.some(function(value,index,arr){return value > 7;})

  • 判断数组中有没有符合条件的元素,只要遇到符合条件的就退出循环。
  • 返回boolean值。

9. 是否都符合:arr.every(function(value,index,arr){return value > 7;})

  • 判断数组中的元素是否都符合条件。
  • 返回boolean值。

10. 过滤数组:arr.filter(function(value,index,arr){return value > 7;})

过滤数组,返回符合条件的元素组成的新数组。

11. 循环数组,无返回值:arr.forEach(function(value,index,arr){})

12. 循环数组,有返回值:arr.map(function(value,index,arr){})

13.汇总:arr.reduce(function(prev,value,index,arr){return prev + value;})

返回数组里面所有元素相加的和。prev是之前那些元素的和。

14. 数组转字符串:String(arr)或arr.toString()

将数组中的元素用逗号连接成字符串,类似于arr.join(“,”)。

15. 开头入栈:arr.unshift(value)

在数组的最开头插入元素。

  • 修改原数组。
  • 返回新数组的length。

16. 开头出栈:arr.shift()

弹出数组最开头的元素。

  • 修改原数组。
  • 返回被弹出的元素。

17. 结尾入栈:arr.push(value1[,value2,arr1])

在数组末尾追加元素。

  • 修改原数组。
  • 返回新数组的length。
  • 追加进去的数组不会被打散。

18. 结尾出栈:arr.pop()

弹出数组最末尾的元素。

  • 修改原数组。
  • 返回被弹出的元素。

二、字符串API

1. 截取:str.slice(from[,end])或str.substring(start[,end])或str.substr(start[,length])

  • slice和substring用法类似,只是slice支持负数,而substring的负数会被转换成0,然后截取0和start之间字符。
  • substr的start支持负数。

2. 分割:str.split(“分割符”)

把字符串以分割符为界点分割成数组。

3. 查找:str.indexOf(value[,from])或str.lastIndexOf(value[,from])

indexOf()只查找第一个,找不到返回-1。

4. 替换:str.replace(“被替换字符”,”替换字符”)

只会替换第一个,如果要替换所有符合条件的字符可以使用正则g。

5. 拼接:str.concat(value)

把value拼接到str上,效果类似于str+value

6. 获取指定位置字符:str.charAt(index)或str[index]

7. 去掉字符串前后空格:str.trim()

8. 字符串转ASCII:str.charCodeAt(index)

9. ASCII转字符串:String.fromCharCode(Unicode)

10. 转大写字母:str.toUpperCase()

11. 转小写字母:str.toLowerCase()

三、4种字符串“查找”方法的对比

1. str.indexOf(value[,from])

只能查找第一个匹配的位置,没找到返回-1,可用循环改变from查找所有。

2. str.search(reg)

  • 仅判断有没有。
  • 只返回第一个匹配的位置,没找到返回-1。
  • 支持正则(不支持g,支持i)。

3. str.match(reg)

  • 返回所有正则匹配的字符串组成的数组,没找到返回null。
  • 支持正则,正则表达式必须带g,才能返回所有匹配的字符串。

4. reg.exec(str)

既能找到关键词的位置,又能获得内容。

  • 支持正则,找不到返回null。
  • 若要查找所有正则必须加g,不加g只能查找第一个,而且要放进循环里面。
1
2
3
4
5
6
7
var str = "大5家好5,谢6谢!";
var reg = /[\d]/g;
console.log(str);
var arr = null;
while((arr = reg.exec(str)) !== null){
console.log(arr)
}