JS数组、字符串及数值的常用方法

一、数组常用方法

关于方法里的第二参数,删除对应的是个数,截取对应的是下标(字符串方法也适用)

(一)添加

1、push():尾部添加

  • push(): 向数组尾部添加一个或多个元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组。
    1
    2
    3
    4
    5
    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]

2、unshift():首项添加

  • unshift():在数组的第一个位置添加元素,并返回添加新元素后的数组长度。注意,该方法会改变原数组
    1
    2
    3
    1 var arr = ['a', 'b', 'c'];
    2 arr.unshift('x'); // 4
    3 console.log(arr); // ['x', 'a', 'b', 'c']

3、concat():多数组合并

  • concat():用于多个数组的合并。它将新数组的成员,添加到原数组的尾部,然后返回一个新数组,原数组不变。
    1
    2
    3
    1 var arr = [1,2,3];
    2 var b = arr.concat([4,5,6]);
    3 console.log(b); //[1,2,3,4,5,6]

(二)删除

1、pop():删除尾部

  • pop(): 删除数组的最后一个元素,并返回该元素。注意,该方法会改变原数组。
    1
    2
    3
    4
    5
    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、shift():删除首位

  • shift():删除数组的第一个元素,并返回该元素。注意,该方法会改变原数组。
    1
    2
    3
    1 var arr = ['a', 'b', 'c'];
    2 arr.shift() // 'a'
    3 console.log(arr) // ['b', 'c']
  • shift()方法还可以遍历并清空一个数组。
    1
    2
    3
    4
    5
    6
    7
    8
    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、splice():删除指定(综合)

  • splice():删除原数组的一部分成员,并可以在被删除的位置添加入新的数组成员,返回值是被删除的元素。注意,该方法会改变原数组。
    splice(start,delNum,addElement1,addElement2,…)第一个参数是删除的起始位置,第二个参数是被删除的元素个数。如果后面还有更多的参数,则表示这些就是要被插入数组的新元素。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    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]

(三)数组查找

1、valueOf(): 返回数组本身

  • valueOf():返回数组的本身。
    1
    2
    1 var arr = [1, 2, 3];
    2 arr.valueOf() // [1, 2, 3]

2、indexOf():查找,没有返-1

  • indexOf():返回指定元素在数组中出现的位置,如果没有出现则返回-1。
    1
    2
    3
    4
    1 var arr = ['a', 'b', 'c'];
    2
    3 arr.indexOf('b') // 1
    4 arr.indexOf('y') // -1
  • indexOf方法还可以接受第二个参数,表示搜索的开始位置。
    1
    2
    1 ['a', 'b', 'c'].indexOf('a', 1)     // -1
    上面代码从1号位置开始搜索字符a,结果为-1,表示没有搜索到。

3、find():返回符合条件的元素

  • 当数组中的元素在测试条件时返回 true 时, find() 返回符合条件的元素,之后的值不会再调用执行函数。

  • 如果没有符合条件的元素返回 undefined
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    实例:

    var ages = [3, 10, 18, 20];

    function checkAdult(age) {
    return age >= 18;
    }

    function myFunction() {
    document.getElementById("demo").innerHTML = ages.find(checkAdult);
    }

    输出结果:18

4、includes() : 返回 true,否则false

  • includes() : 用来判断一个数组是否包含一个指定的值,如果是返回 true,否则false。
    1
    2
    3
    4
    5
    6
    参数说明:

    arr.includes(searchElement, fromIndex)

    1、searchElement:必须。需要查找的元素值。
    2、fromIndex:可选。从该索引处开始查找 searchElement。如果为负值,则按升序从 array.length + fromIndex 的索引开始搜索。默认为 0
    1
    2
    3
    4
    5
    6
    实例:

    var arr = ['a', 'b', 'c'];

    arr.includes('c', 3); //false
    arr.includes('c', 100); // false

5、filter():过滤

  • filter(): 参数是一个函数,所有数组成员依次执行该函数,返回结果为true的成员组成一个新数组返回。(不改变原数组)
    1
    2
    3
    4
    5
    6
    7
    参数说明:

    function(currentValue, index, arr):必须。为一个函数,数组中的每个元素都会执行这个函数。其中函数参数:

    1、currentValue:必须。当前元素的的值。
    2、index:可选。当前元素的索引。
    3、arr:可选。当前元素属于的数组对象。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    实例:

    var arr = [1, 2, 3, 4, 5]
    arr.filter(function (elem) {
    return (elem > 3);
    })
    // [4, 5]

    返回数组,包含了符合条件的所有元素。如果没有符合条件的元素则返回空数组。

6、some():有一个满足(返回true)

  • some() :方法用于检测数组中的元素是否满足指定条件(不改变原数组)
    1
    2
    3
    4
    5
    6
    7
    参数说明:

    function(currentValue, index, arr):必须。为一个函数,数组中的每个元素都会执行这个函数。其中函数参数:

    1、currentValue:必须。当前元素的的值。
    2、index:可选。当前元素的索引。
    3、arr:可选。当前元素属于的数组对象。
    1
    2
    3
    4
    5
    6
    实例:

    const arr = [1,2,3,4]; arr.some((item)=>{return item>1})

    如果有一个元素满足条件,则表达式返回true , 剩余的元素不会再执行检测。
    如果没有满足条件的元素,则返回false

7、every() :全满足(返回true),不改变原数组

  • every() :方法用于检测数组所有元素是否都符合指定条件(不改变原数组)
    1
    2
    3
    4
    5
    6
    7
    参数说明:

    function(currentValue, index, arr):必须。为一个函数,数组中的每个元素都会执行这个函数。其中函数参数:

    1、currentValue:必须。当前元素的的值。
    2、index:可选。当前元素的索引。
    3、arr:可选。当前元素属于的数组对象。
    1
    2
    3
    4
    5
    6
    实例:

    const arr = [1,2,3,4]; arr.every((item)=>{return item>1})

    如果数组中检测到有一个元素不满足,则整个表达式返回 false ,且剩余的元素不会再进行检测。
    如果所有元素都满足条件,则返回 true

(四)数组转字符串

1、toString():返回逗号分割的字符串

  • toString():返回数组的字符串形式。
    1
    2
    3
    4
    5
    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"

2、join():相对于tosting,可以自定义分隔符

  • join():以参数作为分隔符,将所有数组成员组成一个字符串返回。如果不提供参数,默认用逗号分隔。
    1
    2
    3
    4
    5
    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"

(五)截取

1、slice()

  • slice():用于截取原数组的一部分,返回一个新数组,原数组不变。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     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"]

    slice(start,end)它的第一个参数为起始位置(从0开始),第二个参数为终止位置(但该位置的元素本身不包括在内)。如果省略第二个参数,则一直返回到原数组的最后一个成员。

(六)排序

1、reverse()

  • reverse():用于颠倒数组中元素的顺序,返回改变后的数组。注意,该方法将改变原数组。
    1
    2
    3
    4
    1 var arr = ['a', 'b', 'c'];
    2
    3 arr.reverse() // ["c", "b", "a"]
    4 console.log(arr) // ["c", "b", "a"]

2、sort()

  • sort():对数组成员进行排序,默认是按照字典顺序排序。排序后,原数组将被改变。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
     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
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
     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 // ]

(七)遍历

1、forEach():改变原数组

  • forEach():对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组。(改变原数组)
    1
    2
    3
    4
    5
    6
    7
    参数说明:

    function(currentValue, index, arr):必须。为一个函数,数组中的每个元素都会执行这个函数。其中函数参数:

    1、currentValue:必须。当前元素的的值。
    2、index:可选。当前元素的索引。
    3、arr:可选。当前元素属于的数组对象。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    实例:

    const items = ['item1', 'item2', 'item3'];
    const copy = [];

    // before
    for (let i=0; i<items.length; i++) {
    copy.push(items[i]);
    }

    // after
    items.forEach(function(item){
    copy.push(item);
    });

2、map():不改变原数组

  • map():对数组的所有成员依次调用一个函数,根据函数结果返回一个新数组。(不改变原数组)
    1
    2
    3
    4
    5
    6
    7
    参数说明:

    function(currentValue, index, arr):必须。为一个函数,数组中的每个元素都会执行这个函数。其中函数参数:

    1、currentValue:必须。当前元素的的值。
    2、index:可选。当前元素的索引。
    3、arr:可选。当前元素属于的数组对象。
    1
    2
    3
    4
    5
    6
    7
    实例:

    let array = [1, 2, 3, 4, 5];
    let newArray = array.map((item) => {
    return item * item;
    })
    console.log(newArray) // [1, 4, 9, 16, 25]

二、字符串常用方法

1、toLowerCase():转小写

  1. toLowerCase(): 把字符串转为小写,返回新的字符串。
    1
    2
    3
    4
    var str="Hello World";
    var str1=str.toLowerCase();
    console.log(str); //Hello World
    console.log(str1); //hello world

2、toUpperCase():转大写

  1. toUpperCase(): 把字符串转为大写,返回新的字符串。
    1
    2
    3
    4
    var str="hello world";
    var str1=str.toUpperCase();
    console.log(str); //hello world
    console.log(str1); //HELLO WORLD

3、charAt():不常用

  1. charAt(): 返回指定下标位置的字符。如果index不在0-str.length(不包含str.length)之间,返回空字符串。
    1
    xxxxxxxxxx var str="hello world";var str1=str.charAt(6);console.log(str1); 

4、charCodeAt():不常用(针对unicode编码)

  1. charCodeAt(): 返回指定下标位置的字符的unicode编码,这个返回值是 0 - 65535 之间的整数。
    1
    2
    3
    4
    5
    6
    var str="hello world";
    var str1=str.charCodeAt(1);
    var str2=str.charCodeAt(-2); //NaN
    console.log(str1); //101

    注意:如果index不在0-str.length(不包含str.length)之间,返回NaN

5、indexOf():返回第一次出现位置

  1. indexOf(): 返回某个指定的子字符串在字符串中第一次出现的位置
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var str="Hello World";
    var str1=str.indexOf("o");
    var str2=str.indexOf("world");
    var str3=str.indexOf("o",str1+1);
    console.log(str1); //4 默认只找第一个关键字位置,从下标0开始查找
    console.log(str2); //-1 没有找到
    console.log(str3); //7

    注意:indexOf()方法对大小写敏感,如果子字符串没有找到,返回-1。第二个参数表示从哪个下标开始查找,没有写则默认从下标0开始查找。

6、lastIndexOf():返回最后一次出现位置

  1. lastIndexOf(): 返回某个指定的子字符串在字符串中最后出现的位置。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var str="Hello World";
    var str1=str.lastIndexOf("o");
    var str2=str.lastIndexOf("world");
    var str3=str.lastIndexOf("o",str1-1);
    console.log(str1); //7
    console.log(str2); //-1
    console.log(str3); //4

    注意:lastIndexOf()方法对大小写敏感,如果子字符串没有找到,返回-1。第二个参数表示从哪个下标开始查找,没有写则默认从最后一个字符处开始查找。

7、slice():常用

  1. slice(): 截取 返回字符串中提取的子字符串。
    1
    2
    3
    4
    5
    6
    7
    8
    var str="Hello World";
    var str1=str.slice(2); //如果只有一个参数,则提取开始下标到结尾处的所有字符串
    var str2=str.slice(2,7); //两个参数,提取下标为2,到下标为7但不包含下标为7的字符串
    var str3=str.slice(-7,-2); //如果是负数,-1为字符串的最后一个字符。提取从下标-7开始到下标-2但不包含下标-2的字符串。前一个数要小于后一个数,否则返回空字符串

    console.log(str1); //llo World
    console.log(str2); //llo W
    console.log(str3); //o Wor

8、substring():常用

  1. substring(): 提取字符串中介于两个指定下标之间的字符(含前不含后)。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var str="Hello World";
    var str1=str.substring(2)
    var str2=str.substring(2,2);
    var str3=str.substring(2,7);
    console.log(str1); //llo World
    console.log(str2); //如果两个参数相等,返回长度为0的空串
    console.log(str3); //llo W

    注意:substring()用法与slice()一样,但不接受负值的参数。

9、substr()

  1. substr(): 返回从指定下标开始指定长度的的子字符串
    1
    2
    3
    4
    5
    6
    7
    8
    9
    var str="Hello World";
    var str1=str.substr(1)
    var str2=str.substr(1,3);
    var str3=str.substr(-3,2);
    console.log(str1); //ello World
    console.log(str2); //ell
    console.log(str3); //rl

    注意:如果没有指定length,返回从下标开始处结尾处的所有字符串。

10、split():字符串转数组

  1. split(): 把字符串分割成字符串数组。
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    var str="AA BB CC DD";
    var string1="1:2:3:4:5";
    var str1=str.split("");//如果把空字符串 ("")用作分割符,那么字符串的每个字符之间都会被分割
    var str2=str.split(" "); //以空格为分隔符
    var str3=str.split("",4); //4指定返回数组的最大长度
    var str4=string1.split(":");
    console.log(str1); // ["A", "A", " ", "B", "B", " ", "C", "C", " ", "D", "D"]
    console.log(str2); //["AA" "BB" "CC" "DD"]
    console.log(str3); //["A", "A", " ", "B"]
    console.log(str4); // ["1", "2", "3", "4", "5"]

11、replace():替换

  1. replace(): 在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。
    1
    2
    3
    4
    var str="hello WORLD";
    var reg=/o/ig; //o为要替换的关键字,不能加引号,否则替换不生效,i忽略大小写,g表示全局查找。
    var str1=str.replace(reg,"**")
    console.log(str1); //hell** W**RLD

12、match():查找所有

  1. match(): 返回所有查找的关键字内容的数组。
    1
    2
    3
    4
    5
    var str="To be or not to be";
    var reg=/to/ig;
    var str1=str.match(reg);
    console.log(str1); //["To", "to"]
    console.log(str.match("Hello")); //null

三、number常用方法

1、parseInt():取整

  1. 丢弃小数部分,保留整数部分
    1
    parseInt(5/2)

2、Math.ceil():向上取整

  1. 向上取整,有小数就整数部分加1
    1
    Math.ceil(5/2)

3、Math.round():四舍五入

  1. 四舍五入.
    1
    Math.round(5/2)

4、Math.floor():向下取整

  1. 向下取整
    1
    Math.floor(5/2)

5、其他

  1. Math 对象的方法
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    abs(x) 返回数的绝对值 1 2 3
    acos(x) 返回数的反余弦值 1 2 3
    asin(x) 返回数的反正弦值 1 2 3
    atan(x) 以介于 -PI/2 与 PI/2 弧度之间的数值来返回 x 的反正切值 1 2 3
    atan2(y,x) 返回从 x 轴到点 (x,y) 的角度(介于 -PI/2 与 PI/2 弧度之间) 1 2 3
    ceil(x) 对一个数进行上舍入。 1 2 3
    cos(x) 返回数的余弦 1 2 3
    exp(x) 返回 e 的指数。 1 2 3
    floor(x) 对一个数进行下舍入。 1 2 3
    og(x) 返回数的自然对数(底为e) 1 2 3
    max(x,y) 返回 x 和 y 中的最高值 1 2 3
    min(x,y) 返回 x 和 y 中的最低值 1 2 3
    pow(x,y) 返回 x 的 y 次幂 1 2 3
    random() 返回 0 ~ 1 之间的随机数 1 2 3
    round(x) 把一个数四舍五入为最接近的整数 1 2 3
    sin(x) 返回数的正弦 1 2 3
    sqrt(x) 返回数的平方根 1 2 3
    tan(x) 返回一个角的正切 1 2 3
    toSource() 代表对象的源代码 1 4 -
    valueOf() 返回一个 Math 对象的原始值