es6 对象新增 ...的运用和说明 Object.keys\Object.values

...不能作用在undefined的数据上 ,否则报上述错误!!!

var attrname = "height";//读取变量的值
    var obj3 = {
        [attrname]:150
   }
console.log(obj3)//height:150

        var obj = {
            a:1,
            b:2
        }
Object.keys values entries 可以操作对象和数组(一般用来操作对象,对象会变成数组,操作数组还是数组)
        console.log(Object.keys(obj))//["a", "b"] 键名
        console.log(Object.values(obj))//["1", "2"] 键值
        console.log(Object.entries(obj))//[Array(2), Array(2)]
        /* for(var attr of Object.keys(obj)){
            console.log(attr)//a,b
        } */
        for(var [key,val] of Object.entries(obj)){
            console.log(key,val)//a 1 b 2
        }

        // 扩展运算符 
        var obj2 = {
            a:1,
            b:2
        }
        // var res = {
        //     ...obj2,
        //     c:3
        // }
        //console.log(res)// {a:1,b:2,c:3}
        var arr = [1,2,3,4]
        console.log(arr)//[1,2,3,4]
        console.log(1,2,3,4)//1,2,3,4
        console.log(...arr)//1,2,3,4  ...把数组打散成为参数
        //...使用情景 也叫剩余参数 只能放最后
        //比较数组值得大小
        var num = [1,42,98,10,22,65]
        console.log(Math.max(num))//NaN
        console.log(Math.max(...num))//98

        //扩展运算符可以与解构赋值结合起来,用于生成数组
        const [first, ...rest] = [1, 2, 3, 4, 5];
        first // 1
        rest  // [2, 3, 4, 5]

        //剩余参数的使用
        function func(a, b, ...rest) {
          console.log(a, b)
          console.log(rest)
        }
        func(1, 2)//1,2 []
        func(1, 2, 3, 4) //1,2 [3,4]
        
        // 只能用于数组,对象不可以
        var list = [
            {
                name:'du',
                age:'18'
            }
        ]
        console.log(...list)//{name: "du", age: "18"}

        扩展运算符还可以将字符串转为真正的数组
        [...'hello']
        // [ "h", "e", "l", "l", "o" ]

取出数组里边对象的key和value值

例如我们有这样一个数组:

let  channelTabList = [
     {1: '推荐'},
     {2: '最新'},
     {3: '快赚'}, 
     {4: '高额'}
]

我们想将他转化为这样的形势可以使用reduce

let lists = channelTabList.reduce((acc,value)=>{
    return {...acc,...value}
})
console.log(lists)//{1: "推荐", 2: "最新", 3: "快赚", 4: "高额"}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

林中明月间。

分享共赢。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值