美文网首页
四.Indexed collections & Keyed cl

四.Indexed collections & Keyed cl

作者: HarryWX | 来源:发表于2018-07-23 13:31 被阅读0次

    Indexed collections

    • 创建数组
    var arr = new Array(element0, element1, ..., elementN);
    
    var arr = Array(element0, element1, ..., elementN);
    
    var arr = [element0, element1, ..., elementN];
    
    • 创建长度非零但不包含任何项目的数组,可以使用以下一项:
    var arr = new Array(arrayLength);
    
    var arr = Array(arrayLength);
    
    // This has exactly the same effect
    var arr = [];
    arr.length = arrayLength;
    
    • 在ES2015中,您可以使用Array.of静态方法来创建具有单个元素的数组。
    让wisenArray = Array.of(9.3); // wisenArray只包含一个元素9.3
    

    数组方法

    • concat()连接两个数组并返回一个新数组
    var myArray = new Array('1', '2', '3');
    myArray = myArray.concat('a', 'b', 'c'); 
    // myArray is now ["1", "2", "3", "a", "b", "c"]
    
    • join(delimiter)将数组的所有元素连接成一个字符串。
    var myArray = new Array('Wind', 'Rain', 'Fire');
    var list = myArray.join(' - '); // list is "Wind - Rain - Fire"
    
    • push()将一个或多个元素添加到数组的末尾,并返回数组的结果长度。
    var myArray = new Array('1', '2');
    myArray.push('3'); // myArray is now ["1", "2", "3"]
    
    • pop()从数组中删除最后一个元素并返回该元素。
    var myArray = new Array('1', '2', '3');
    var last = myArray.pop(); 
    // myArray is now ["1", "2"], last = "3"
    
    • shift()从数组中删除第一个元素并返回该元素。
    var myArray = new Array('1', '2', '3');
    var first = myArray.shift(); 
    // myArray is now ["2", "3"], first is "1"
    
    • unshift()将一个或多个元素添加到数组的前面并返回数组的新长度。
    var myArray = new Array('1', '2', '3');
    myArray.unshift('4', '5'); 
    // myArray becomes ["4", "5", "1", "2", "3"]
    
    • slice(start_index,uptp_index)从数组提取一个片段,并作为一个新数组返回。
    var myArray = new Array ("a", "b", "c", "d", "e");
    myArray = myArray.slice(1, 4); // starts at index 1 and extracts all elements
                                   // until index 3, returning [ "b", "c", "d"]
    
    • splice(index,count_to_remove,addElement1,addelement2,...)从数组移除一些元素,(可选)并替换它们。
    var myArray = new Array ("1", "2", "3", "4", "5");
    myArray.splice(1, 3, "a", "b", "c", "d"); 
    // myArray is now ["1", "a", "b", "c", "d", "5"]
    

    reverse()颠倒数组元素的顺组:第一个变成最后一个,最后一个变成第一个。

    var myArray = new Array ("1", "2", "3");
    myArray.reverse(); 
    // transposes the array so that myArray = [ "3", "2", "1" ]
    

    +sort()给数组元素排序,若没带回调函数,则按unicode码排序。

    var myArray = new Array("Wind", "Rain", "Fire");
    myArray.sort(); 
    // sorts the array so that myArray = [ "Fire", "Rain", "Wind" ]
    
    • indexOf(searchElement[,fromIndex])在数组中搜索searchElement并返回第一个匹配的索引。
    var a = ['a', 'b', 'a', 'b', 'a'];
    console.log(a.indexOf('b')); // logs 1
    // Now try again, starting from after the last match
    console.log(a.indexOf('b', 2)); // logs 3
    console.log(a.indexOf('z')); // logs -1, because 'z' was not found
    
    • lastIndexOf(searchElement[,fromIndex])和indexOf差不多,但这是从结尾开始,并且是反向搜索。
    var a = ['a', 'b', 'c', 'd', 'a', 'b'];
    console.log(a.lastIndexOf('b')); // logs 5
    // Now try again, starting from before the last match
    console.log(a.lastIndexOf('b', 4)); // logs 1
    console.log(a.lastIndexOf('z')); // logs -1
    
    • reduce(callback)使用回调函数callback把数组列表计算成一个单一值。

    Keyed collections

    • ES2015引入了一个新的数据结构来将一个值映射到另一个值。一个Map对象就是一个简单的健值对映射集合,可以按照。
    var sayings = new Map();
    sayings.set('dog', 'woof');
    sayings.set('cat', 'meow');
    sayings.set('elephant', 'toot');
    sayings.size; // 3
    sayings.get('fox'); // undefined
    sayings.has('bird'); // false
    sayings.delete('dog');
    sayings.has('dog'); // false
    
    for (var [key, value] of sayings) {
      console.log(key + ' goes ' + value);
    }
    // "cat goes meow"
    // "elephant goes toot"
    
    sayings.clear();
    sayings.size; // 0
    

    Objects和Map的比较

    • 一般地,objects会被用于将字符串类型映射到数值。Object允许设置键值对、根据键获取值、删除键、检测某个键是否存在。而Map具有更多的优势。

      • Object的键均为Strings类型,在Map里键可以是任意类型。
      • 必须手动计算Object的尺寸,但是可以很容易地获取使用Map的尺寸。
      • Map的遍历遵循元素的插入顺序。
      • Object有原型,所以映射中有一些缺省的键。

    集合

    • Set对象是一组值的集合,这些值是不重复的,可以按照添加顺序来遍历。
    var mySet = new Set();
    mySet.add(1);
    mySet.add("some text");
    mySet.add("foo");
    
    mySet.has(1); // true
    mySet.delete("foo");
    mySet.size; // 2
    
    for (let item of mySet) console.log(item);
    // 1
    // "some text"
    

    Array和Set的对比

    • 一般情况下,在JavaScript中使用数组来存储一组元素,而新的集合对象有这些优势:
      • 数组中用于判断元素是否存在的indexOf函数效率低下。
      • Set对象允许根据值删除元素,而数组中必须使用基于下标的splice方法。
      • 数组的indexOf方法无法找到NaN值。
        +Set对象存储不重复的值,所以不需要手动处理包含重复值的情况。

    相关文章

      网友评论

          本文标题:四.Indexed collections & Keyed cl

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