js数组API和字符串API汇总
一、数组API1. 连接:arr.join("连接符")用连接符把数组里面的元素连接成字符串。arr.join("")能无缝连接。拼接:arr.concat(“a”,“b”,arr1)强调:(1)不会修改原数组,返回新数组。(2)concat方法中的数组会被打散为
一、数组API
1. 连接:arr.join("连接符")
用连接符把数组里面的元素连接成字符串。
arr.join("")能无缝连接。
2. 拼接:arr.concat("a","b",arr1)
强调:(1)不会修改原数组,返回新数组。
(2)concat方法中的数组会被打散为单个元素再拼接。
3. 截取:arr.slice(start[,end])
强调:(1)不会修改原数组,返回新的子数组。
(2)含头不含尾。
(3)省略第二个参数表示从start位置开始一直截取到末尾。
(4)支持负数,表示倒数第几个。
4. 删除、插入、替换:arr.splice(start,n[,value1,value2...])
强调:(1)直接修改原数组。
(2)返回所有被删除元素组成的子数组。
(3)如果是插入,删除了0个数,那么从start位置开始以及之后的元素会被顺移。
5. 翻转数组:arr.reverse()
强调:(1)直接修改原数组。
6. 数组排序:arr.sort()
强调:(1)直接修改原数组。
(2)默认按照数组元素第一位的ASCII码从小到大排列。
(3)可以设置下列的比较器函数来控制升序,降序或者打乱。
(4)arr.sort(function(a,b){return a-b;}); 升序(只限数组中是数字或者数字字符串)。
(5)arr.sort(function(a,b){return b-a;}); 降序(只限数组中是数字或者数字字符串)。
(6)arr.sort(function(){
return Math.random()>.5 ? 1 : -1;
});随机打乱数组(数组中可以是任何数据类型)
7. 查找:arr.indexOf(value[,from])或arr.lastIndexOf(value[,from])
强调:(1)返回value在数组中的位置,没有找到返回-1。
8. 是否有符合的:arr.some(function(value,index,arr){
return value > 7;
})
强调:(1)判断数组中有没有符合条件的元素,只要遇到符合条件的就退出循环。
(2)返回boolean值。
9. 是否都符合:arr.every(function(value,index,arr){return value > 7;})
强调:(1)判断数组中的元素是否都符合条件。
(2)返回boolean值。
10. 过滤数组:arr.filter(function(value,index,arr){return value > 7;})
强调:(1)过滤数组,返回符合条件的元素组成的新数组。
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)
在数组的最开头插入元素。
强调:(1)修改原数组。
(2)返回新数组的length。
16. 开头出栈:arr.shift()
弹出数组最开头的元素。
强调:(1)修改原数组。
(2)返回被弹出的元素。
17. 结尾入栈:arr.push(value1[,value2,arr1])
在数组末尾追加元素。
强调:(1)修改原数组。
(2)返回新数组的length。
(3)追加进去的数组不会被打散。
18. 结尾出栈:arr.pop()
弹出数组最末尾的元素。
强调:(1)修改原数组。
(2)返回被弹出的元素。
二、字符串API
1. 截取:str.slice(from[,end])或str.substring(start[,end])或str.substr(start[,length])
强调:(1)slice和substring用法类似,只是slice支持负数,而substring的负数会被转换成0,然后截取0和start之间字符。
(2)substr的start支持负数。
2. 分割:str.split("分割符")
把字符串以分割符为界点分割成数组。
3. 查找:str.indexOf(value[,from])或str.lastIndexOf(value[,from])
强调:(1)indexOf()只查找第一个,找不到返回-1。
4. 替换:str.replace("被替换字符","替换字符")
强调:(1)只会替换第一个,如果要替换所有符合条件的字符可以使用正则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)只能查找第一个匹配的位置,没找到返回-1,可用循环改变from查找所有。
2. str.search(reg)
强调:(1)仅判断有没有。
(2)只返回第一个匹配的位置,没找到返回-1。
(3)支持正则(不支持g,支持i)。
3. str.match(reg)
强调:(1)返回所有正则匹配的字符串组成的数组,没找到返回null。
(2)支持正则,正则表达式必须带g,才能返回所有匹配的字符串。
4. reg.exec(str)
既能找到关键词的位置,又能获得内容。
强调:(1)支持正则,找不到返回null。
(2)若要查找所有正则必须加g,不加g只能查找第一个,而且要放进循环里面。
-
var str =
"大5家好5,谢6谢!";
-
var reg =
/[\d]/g;
-
console.log(str)
-
var arr =
null;
-
while((arr = reg.exec(str)) !==
null){
-
console.log(arr)
-
}
更多推荐
所有评论(0)