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: 搜索的字符串.

image.png

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)。原始数组不会被改变。


Daotin
24 声望0 粉丝

大家好,我是前端队长Daotin,关注我解锁前端成长新姿势(全网同名)。