# js字符串/数组常用方法
# 字符串
# charAt
str.charAt(index);
从一个字符串中获取索引为index的字符。
# startsWith, endsWith
str.endsWith(searchString[, length])
length 可选。作为 str 的长度。默认值为 str.length。
endsWith()方法用来判断当前字符串是否是以另外一个给定的子字符串“结尾”的,根据判断结果返回 true 或 false。
# search
语法:str.search(substr|regexp)
说明:查找满足字符串substr或者正则表达式regexp的str中第一次出现的索引,Eugene没找到返回-1.
PS:如果传入一个非正则表达式对象,则会使用 new RegExp(obj) 隐式地将其转换为正则表达式对象。
# match
语法:str.match(regexp);
regexp:一个正则表达式对象。如果传入一个非正则表达式对象,则会隐式地使用 new RegExp(obj) 将其转换为一个 RegExp 。如果你未提供任何参数,直接使用 match() ,那么你会得到一个包含空字符串的 Array :[""] 。
说明:返回一个根据正则表达式regexp查找str的所有匹配的字符串,然后将匹配的字符串集合以数组形式返回。
如果使用g标志,则将返回与完整正则表达式匹配的所有结果;
如果未使用g标志,则仅返回第一个完整匹配及其相关的捕获组
捕获组:
groups: 一个捕获组数组 或 undefined(如果没有定义命名捕获组)。
index: 匹配的结果的开始位置
input: 搜索的字符串.
# padStart, padEnd
str.padStart(targetLength [, padString])
padString 填充字符串。默认为空字符串。
用另一个字符串填充当前字符串(重复,如果需要的话),以便产生的字符串达到给定的长度。
# replace
语法:str.replace(regexp|substr, newSubStr|function)
说明:返回一个由替换值替换一些或所有匹配的模式后的新字符串。他不会改变原字符串。
regexp|substr:将要被替换的字符串或者正则表达式
newSubStr|function:新的字符串或者一个用来创建新子字符串的函数。
只会替换第一个匹配到的字符串,除非用正则+g的形式。
# split
语法:str.split([separator[, limit]])
说明:以separator为分割标志,分割出limit个数的字符串。没有limit的话,全部分割。
# search
str.search(str/regexp)
返回字符串/正则表达式在字符串中首次匹配项的索引,否则返回 -1。
'aaababcc'.search('abc') // 4
# substring
语法:str.substring(indexStart[, indexEnd])
说明:返回一个字符串在开始索引到结束索引之间的一个子集, 或从开始索引直到字符串的末尾的一个子集。
- 如果 indexStart 等于 indexEnd,substring 返回一个空字符串。
- 如果省略 indexEnd,substring 提取字符一直到字符串末尾。
- 如果任一参数小于 0 或为 NaN,则被当作 0。
- 如果任一参数大于 stringName.length,则被当作 stringName.length。
- 如果 indexStart 大于 indexEnd,则 substring 的执行效果就像两个参数调换了一样。见下面的例子。
# toUpperCase, toLowerCase
# trim, trimStart, trimEnd
语法:str.trim()
说明:去除str两端空格。trim() 方法并不影响原字符串本身,它返回的是一个新的字符串。
相应的:
str.trimLeft(); // 去除str左边空格
str.trimRight(); // 去除str右边空格
# valueOf(), toString
str.valueOf()
str.toString()
返回指定字符串对象的字符串形式。
# 数组
# isArray
Array.isArray(obj)
检测参数是不是数组对象Array。
# of
创建一个具有可变参数数量的新数组。
Array.of(1); // [1]
Array.of(1, 2, 3); // [1, 2, 3]
Array.of(undefined); // [undefined]
# forEach
特点:无返回值(返回 undefined),纯遍历数组中的元素。
注意:不能使用element直接修改数组的元素,可以使用arr[index]来修改。
var arr = ["关长","张飞","赵子龙","马超","黄忠"];
var str = "";
// function (element,index,array)
// element:数组元素的值
// index:索引
// array:调用这个方法的整个数组对象(一般不用)
arr.forEach(function (ele,index,array) {
str+=ele;
});
console.log(str); // 关长张飞赵子龙马超黄忠
注意:
只写一个参数就是 element;
写两个参数就是 element 和 index
写三个参数就是: element 和 index 和 array本身。
# map
创建一个新数组,其结果是该数组中的每个元素都调用一次提供的函数后的返回值。
注意:map可以直接使用ele修改数组里面的值。这是与forEach的区别,
还有一个区别是map有返回值,而forEach没有。
var arr = ["关长","张飞","赵子龙","马超","黄忠"];
var arr2 = arr.map(function (ele,index,array) {
return ele+"你好";
})
console.log(arr2); // (5) ["关长你好", "张飞你好", "赵子龙你好", "马超你好", "黄忠你好"]
# every
测试一个数组内的所有元素是否都能通过某个指定函数的测试。返回值是一个 boolean 类型值。而参数是一个回调函数。 参数有三个。名字随便起,但是表示的意思还是这样顺序的。
特点:只要有一个不满足条件,就返回false。
var arr = ["青花瓷", "一路向北", "轨迹"];
var flag = arr.every(function (ele, index) { // 只要有一个没满足条件,就返回false
return ele.length > 2;
});
console.log(flag); // false
# some
特点:如果函数结果有一个是true,那么some方法结果也是true。
var arr = ["关长","张飞","赵子龙","马超","黄忠"];
var flag = arr.some(function (ele,index,array) {
if(ele.length>2){
return true;
}
return false;
})
console.log(flag); // true
# filter
创建一个新数组, 其包含通过所提供函数实现的测试的所有元素。
var arr = ["关长","张飞","赵子龙","马超","黄忠"];
var arr1 = arr.filter(function (ele,index,array) {
return ele.length > 2;
});
console.log(arr1); // ["赵子龙"]
# fill
arr.fill(value[, start[, end]])
value:用来填充数组元素的值。
start 可选,起始索引,默认值为0。
end 可选,终止索引,默认值为 this.length。
用一个固定值填充一个数组中从起始索引到终止索引内的全部元素。不包括终止索引。
# find, findIndex
arr.find(function(item, index, arr) {})
返回数组中满足提供的测试函数的第一个元素的值。否则返回 undefined。
# flat
var newArray = arr.flat([depth])
depth:要提取嵌套数组的结构深度,默认值为 1。
扁平化数组。
var arr1 = [1, 2, [3, 4]];
arr1.flat(); // [1, 2, 3, 4]
var arr2 = [1, 2, [3, 4, [5, 6]]];
arr2.flat();// [1, 2, 3, 4, [5, 6]]
var arr3 = [1, 2, [3, 4, [5, 6]]];
arr3.flat(2); // [1, 2, 3, 4, 5, 6]
//使用 Infinity,可展开任意深度的嵌套数组
var arr4 = [1, 2, [3, 4, [5, 6, [7, 8, [9, 10]]]]];
arr4.flat(Infinity); // [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
// flat() 方法会移除数组中的空项
var arr4 = [1, 2, , 4, 5];
arr4.flat(); // [1, 2, 4, 5]
# join
将一个数组的所有元素连接成一个字符串并返回这个字符串。
arr.join([separator])
separator 指定一个字符串来分隔数组的每个元素。默认用逗号(,)分隔。如果separator是空字符串(""),则所有元素之间都没有任何字符。
# push, pop, shift, unshift
arr.push(element1, ..., elementN)
arr.pop()
push:将一个或多个元素添加到数组的末尾,并返回该数组的新长度。
pop:从数组中删除最后一个元素,并返回该元素的值。此方法更改数组的长度。
unshift:将一个或多个元素添加到数组的开头,并返回该数组的新长度。
shift:从数组中删除第一个元素,并返回该元素的值。此方法更改数组的长度。
# reduce, reduceRight
对数组中的每个元素(从左到右)应用一个函数,将其简化为单个值。
var arr = [1,2,3,4,5];
var arr2 = arr.reduce(function(a,b){
return a-b; // 1-2-3-4-5 = -13
});
var arr = [1,2,3,4,5];
var arr2 = arr.reduceRight(function(a,b){
return a-b; // 5-4-3-2-1 = -5
});
# reverse
arr.reverse()
将数组中元素的位置颠倒,并返回该数组。该方法会改变原数组。
# sort
给数组排序(只能通过第一位字母或数字的 unicode 编码进行排列),返回排序后的数组。
var arr2 = [7,6,15,4,13,2,1];
console.log(arr2); // 7,6,15,4,13,2,1
console.log(arr2.sort()); // 1,13,15,2,4,6,7
解决:可以通过回调函数进行规则设置。
console.log(arr2.sort(function (a,b) {
return a-b; //a-b,从小到大排序,如果是b-a则从大到小排序
}));
# splice
array.splice(startIndex [, deleteCount[, additem1[, additem2[, ...]]]])
通过删除或替换现有元素或者原地添加新的元素来修改数组,并以数组形式返回被修改的内容。此方法会改变原数组。
# toString
将数组转换成字符串。
[1,2,[3,[4,[5]]]].toString() // "1,2,3,4,5"
[1,2,[3,[4,[5, 'aaa']]]].toString() //"1,2,3,4,5,aaa"
[1,2,[3,[4,[5, {a:1} ]]]].toString() //"1,2,3,4,5,[object Object]"
# 字符串&数组共有
# concat
字符串:
str.concat(string2, string3[, ..., stringN])
将一个或多个字符串与原字符串连接合并,形成一个新的字符串并返回。它不影响原字符串。
数组:
var new_array = old_array.concat(value1[, value2[, ...[, valueN]]])
用于合并两个或多个数组。此方法不会更改现有数组,而是返回一个新数组。
# includes
字符串:
str.includes(searchString[, position])
position 可选。从str字符串的哪个索引位置开始搜寻子字符串,默认为0。
用于判断一个字符串是否包含在另一个字符串中,返回 true 或 false。
数组:
arr.includes(valueToFind[, fromIndex])
从fromIndex 索引处开始查找 valueToFind。如果为负值,则按升序从 array.length + fromIndex 的索引开始搜 (即使从末尾开始往前跳 fromIndex 的绝对值个索引,然后往后搜寻)。默认为 0。
判断一个数组是否包含一个指定的值,返回true/false。
# indexOf(), lastIndexOf()
字符串:
语法:str.indexOf(searchValue[, fromIndex])
说明:从fromIndex索引开始(可省略。默认为0 )从前往后查找,第一次出现searchValue的索引值。如果没有找到返回 -1.
语法:str.lastIndexOf(searchValue[, fromIndex])
说明:从fromIndex索引开始(可省略。默认为0 )从前往后查找,最后一次出现searchValue的索引值。如果没有找到返回 -1。
数组:
arr.indexOf/lastIndexOf(searchValue)
查找数组中有没有某个元素,找到了返回这个元素在数组中的索引,如果没找到返回-1。
# slice
字符串:
语法:str.slice(beginSlice[, endSlice])
beginSlice
:从该索引(以 0 为基数)处开始提取原字符串中的字符。如果值为负数,会被当做 strLength + beginIndex 看待,这里的strLength 是字符串的长度(例如, 如果 beginIndex 是 -3 则看作是:strLength - 3)
endSlice
:可选。在该索引(以 0 为基数)处结束提取字符串。如果省略该参数,slice() 会一直提取到字符串末尾。如果该参数为负数,则被看作是 strLength + endIndex,这里的 strLength 就是字符串的长度(例如,如果 endIndex 是 -3,则是, strLength - 3)。
说明:提取一个字符串的一部分,并返回一新的字符串,且不会改动原字符串。
数组:
arr.slice(startIndex,endIndex);
返回一个新的数组对象,这一对象是一个由 startIndex和 endIndex 决定的原数组的浅拷贝(包括 startIndex,不包括endIndex)。原始数组不会被改变。