JS常见数组操作大全

作者: HelloKing | 来源:发表于2018-08-02 09:13 被阅读3次

    - concat()//链接数组

    - slice()//从当前数组中截取一个数组,不影响原来的数组,参数start是从0开始,end是从1开始;

    Eg: var arr4 = arr3.slice(2)//从index=2位置上往后截取,给arr4。arr3原数组不变。

    var arr4 = arr3.slice(2,4)索引值包左不包右

    - splice()//删除或者替换当前数组的某些项目,参数start,deleteCount,options(要替换的项目)

    Eg: var arr4 = arr3.splice(0,3 )//0是从第一个为直接去,截取3个。arr3原数组改变。

    var arr4 = arr3.splice(0,3 )//0是从第一个为直接去,截取3个。arr3原数组改变。

    var arr4 = arr3.splice(0,3 ,“1”)//0是从第一个为直接去,截取3个。arr3原数组改变,1补充到arr3中,

    //替换的元素不能以数组的形式存在否则会将整个元素放在原数组中。

    位置方法:

    -indexOf()

    indexOf()给元素查索引,如果没找到返回-1

    var = [“a”,”b”,”c”,”a”]

    eg: var index1 = arr.indexOf(“a”) //index1 = 0.从前往后查索引,返回最先查到元素的索引。

    var index2 =  lastIndex()//index1 = 3.从后往前查索引,返回最先查到元素的索引。

    迭代方法不会修改原数组,代替for循环。

    - every(), fiter(),forEach(),map()  ,    some()

    every() 方法用于检测数组所有元素是否都符合指定条件(通过函数提供)。

    every() 方法使用指定函数检测数组中的所有元素:

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

    如果所有元素都满足条件,则返回 true。

    注意: every() 不会对空数组进行检测。

    注意: every() 不会改变原始数组。

    array.every(function(item, index, arr){

    return true;

    })

    Eg:修改数组元素

    array.every(function(item, index, arr){

    array[index] = “111”

    return true;

    })

    fiter()返回值是一个新数组。return为true的数组。

    var arr = [1500,1200,2000,2100,1800];

    Var arr1 = arr.filter(function(ele, index,arr){

    If(ele.length < 2000){

    return true

    }

    return false

    });

    结果:arr1 = [1500,1200,1800];

    forEach()纯便利数组,没有返回值(纯操作数组中的元素)

    arr.forEach(function(ele, index,arr){

    });

    Eg:检查数组中元素出现的个数;

    思路:创建一个对象,判断数组中的元素在对象中在对象中属否存,如果存在,值加一;否则创建一个数组元素的属性,并赋值一。

    var arr5 = ["c","a","x","a","x","a"];

    var json = {};

    arr5.forEach(function(ele, index,arr){

    if(json[arr5[i]]){

    json[arr5[i]] += 1;

    }else{

    json[arr5[i]] = 1;

    }

    });

    Console.log(json)//结果:json = {"c" : 1, "a" : 3, "x" : 4}

    map()  对数组中每一项运行一下函数,返回该函数的结果组成新数组

    var = arr.map(function(item, index, arr){

    return “\” + item “\”;

    })//整个数组元素都改变

    //对数组中每一项运行一下函数,如果该函数某一项返回true,剩余的元素不会再执行检测。如果没有满足条件的元素,则返回false

    注意: some() 不会对空数组进行检测。

    注意: some() 不会改变原始数组。

    var b = array.some(function(item,index,arr){

    if(item == "ww"){

    return true;

    }

    return false;

    })

    //清空数组

    方法一:

    var Arr = array[1,2,3];

    Arr.splice(0);

    方法二:

    var Arr = array[1,2,3];

    Arr.length = 0;

    方法三:

    var Arr = array[1,2,3];

    Arr = [];

    构造函数原理:

    var num = new Number(111)

    Console.log(num)

    //结果返回的是一个对象

    var num = Number(“111”)

    Console.log(num)

    //结果返回的是一个值

    相关文章

      网友评论

        本文标题:JS常见数组操作大全

        本文链接:https://www.haomeiwen.com/subject/qdfjvftx.html