zoukankan      html  css  js  c++  java
  • es6 语法 (数组扩展)

    {
        let arr = Array.of(3, 4, 7, 9, 11);
        console.log('arr', arr); //[3,4,7,9,11]
        let empty = Array.of();
        console.log(empty); //[]
    }
    //ES6为Array增加了from函数用来将其他对象转换成数组。
    
    //当然,其他对象也是有要求,也不是所有的,可以将两种对象转换成数组。
    
    //1.部署了Iterator接口的对象,比如:Set,Map,Array。
    
    //2.类数组对象,什么叫类数组对象,就是一个对象必须有length属性,没有length,转出来的就是空数组。
    {
        //转换数组
        let p = document.querySelectorAll('p');
        let pArr = Array.from(p);
        pArr.forEach(function(item) {
            console.log(item.textContent); //es6,嘿嘿嘿,快乐动起来
        });
        //map
        console.log(Array.from([1, 3, 5], function(item) {
                return item * 2
            })) //2,6,10
    }
    
    //数组填充
    {
        console.log('fill-7', [1, 'a', undefined].fill(7)) // 7,7,7
        console.log('fll,pos', ['a', 'b', 'c'].fill('7', 1, 3)); //a 7 7 (1,3)表示起始位置,7为填充内容
    }
    //遍历相关
    {
        //取位置
        for (let index of['1', 'c', 'ks'].keys()) {
            console.log('keys', index); //0 1 2
        }
        //取值
        for (let value of['1', 'c', 'ks'].values()) {
            console.log('values', value); //1 c ks (这里有兼容问题,需引入 import 'babel-polyfill')
        }
        //取位置和值
        for (let [index, value] of['1', 'c', 'ks'].entries()) {
            console.log('values', index, value); //0 1 2,1 c ks
        }
    }
    //在当前数组内部数组内一个成员赋值到其他地方
    {
        console.log([1, 2, 3, 4, 5].copyWithin(0, 3, 4)); //4,2,3,4,5 (开始位置0,从第三个开始读起,截止位置为4,即5个数)
        console.log([1, 2, 3, 4, 5].copyWithin(1, 3, 4)) //1,4,3,4,5
        console.log([1, 2, 3, 4, 5].copyWithin(0, -2, -1)) //4,2,3,4,5
    }
    //查找
    {
        console.log([1, 2, 3, 4, 5, 6].find(function(item) {
            return item > 3 //4 只找第一个值,不往后了
        }));
        console.log([1, 2, 3, 4, 5, 6].findIndex(function(item) {
            return item > 3 //3 找的是下标
        }));
    }
    //NaN 
    {
        console.log('number',[1,2,NaN].includes(1)); // true 是否包含这个值
        console.log('number',[1,2,NaN].includes(NaN)); // true
    }
  • 相关阅读:
    模版的完全特化与偏特化
    [转]windows消息机制(MFC)
    MFC宏常识
    半透明AlphaBlend
    new、operator new、placement new
    DuplicateHandle
    Mac OS X 更新JAMF域控配置
    生成自签名CA+SSL证书
    Office 2016系列下载地址
    Spring Security静态资源访问
  • 原文地址:https://www.cnblogs.com/Byme/p/7615594.html
Copyright © 2011-2022 走看看