1.解构: 不定参数,扩展表达式

         let arr = [100, 201, 303, 911];
let [one, ...others] = arr;
console.log(others.length); //
console.log(one); //
console.log(others[0]); //
console.log(others[1]); //

1.2 解构:数组自身链接返回自身

         // 数组链接返回自身
let arr = [10, 20, 30];
let newArr = arr.concat();
console.log(newArr); //[10, 20, 30]

1.3 解构:

         let arr = [10, 20, 30, 200];
let [...newArr] = arr;
console.log(newArr);

1.4 解构:

         let User = {
name: 'aluoha',
age: 25,
class: {
group1: {
one: '马援',
two: '路博德'
},
group2: {
one: '卫青',
two: '刘邦'
}
},
arr: [10, 20, 30]
};
let {name,age,class: {group1},arr} = User;
console.log(name, age, group1, group1.two, arr); //aluoha 25 Object{} 路博德 [10,20,30]

1.4.2 解构:

   let User = {
name: 'aluoha',
age: 25,
class: {
group1: {
one: '张飞',
two: '关羽'
},
group2: {
one: '徐晃',
two: '丁典'
}
},
arr: [10, 20, 30]
};
let {
name,
age,
class: {
group1, group2
},
arr: [one, two, three]
} = User;
console.log(name, age, group1.one, group1.two, group2.one, group2.two, one, two, three);
</script>

2. 杂项:如何反转一个对象的键值对:即将键和值反转

2.1 使用Object.keys()  获取一个对象的属性数组

       var obj = {
a: 10,
b: 20,
c: 30
};
var keys = Object.keys(obj); //可以获取到对象的键,组成的数组
console.log(keys);

2.2 对obj 进行键值反转:

         var obj = {
a: 10,
b: 20,
c: 30
};
var keys = Object.keys(obj); //可以获取到对象的键,组成的数组
console.log(keys); // ['a','b','c']
var res = {};
keys.forEach((val) => {
res[obj[val]] = val;
});
console.log(res); // {10:'a',20:'b',30:'c'}

2.3 使用hasOwnProperty()  来实现键值对反转

2.3.1  确认一下 hasOwnProperty 是否有效

         function Myobj() {
this.a = 10;
this.b = 20;
this.c = 30;
}
Myobj.prototype.d = 40; // 在原型对象上加入一个属性 d ,值为 40
var obj = new Myobj(); // 创建一个对象
console.log(obj.d); //
console.log(obj.hasOwnProperty('d')); // false

结果:obj 能够调用d 的值,但是d 不是obj 本身的属性,所以显示false

2.3.2 键值对反转实现:

 function Myobj() {
this.a = 10;
this.b = 20;
this.c = 30;
}
var obj = new Myobj(); // 创建一个对象
var keys = []; //创建一个空数组接受obj 的键
for (var key in obj) {
if (obj.hasOwnProperty(key)) {
keys.push(key);
}
};
var res = {}; //创建一个空对象接受反转后的对象
for (var i = 0, len = keys.length; i < len; i++) {
res[obj[keys[i]]] = keys[i];
}
console.log(obj);
console.log(res);

es6初级之解构----之二 及 键值反转实现的更多相关文章

  1. es6初级之解构----之一

    1. 访问对象属性 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...

  2. ES6入门之变量的解构赋值(二)

    前言 在上一章 ES6入门之let和const命令中我们对ES6的相关语法已经有了初步了解,上一章中我们主要学习了三大部分的内容,let命令的使用,块级作用域,const命令的使用,那么从本篇博客将进 ...

  3. ES6里的解构赋值

    我们经常定义许多对象和数组,然后有组织地从中提取相关的信息片段.在ES6中添加了可以简化这种任务的新特性:解构.解构是一种打破数据结构,将其拆分为更小部分的过程. 一.引入背景 在ES5中,开发者们为 ...

  4. ES6 - 变量的解构赋值学习笔记

    变量的解析赋值 数组的解析赋值 es6允许按照一定的模式,从数组和对象中提取值,对变量进行赋值,这就称为解构. var a = 1; var b = 2; var c = 3; //在es6中允许写成 ...

  5. es6学习笔记--解构赋值

    昨天学习了es6语法中解构赋值,解构赋值在声明中和函数传参提高了灵活性和便捷性,值得掌握该语法. 概念: ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构.   数组的解构 ...

  6. 关于ES6 的对象解构赋值

    之 前写了关于ES6数组的解构 现在 go on ; 解构不仅可以用于数组,还可以用于对象: 对象的解构和数组有一个重要的不同.数组的元素是按次序排列的,变量的取值是由他的位置决定的:而对象的属性没有 ...

  7. es6变量的解构赋值学习笔记

    1. 解构赋值的规则是,只要等号右边的值不是对象,就先将其转为对象.由于undefined和null无法转为对象,所以对它们进行解构赋值,都会报错. let { prop: x } = undefin ...

  8. ES6 数组的解构赋值

    数组的解构赋值 ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构(Destructuring). 以前,为变量赋值,只能直接指定值. let a = 1; let b = ...

  9. ES6变量的解构赋值

    变量的解构赋值 1.数组的解构赋值 2.对象的解构赋值 3.字符串的解构赋值 4.数值和布尔值的解构赋值 5.函数参数的解构赋值 6.圆括号问题 7.用途 1.数组的解构赋值 ES6 允许写成下面这样 ...

随机推荐

  1. 配置允许匿名用户登录访问vsftpd服务,进行文档的上传下载、文档的新建删除等操作

    centos7环境下 临时关闭防火墙 #systemctl stop firewalld 临时关闭selinux #setenforce 0 安装ftp服务 #yum install vsftpd - ...

  2. linux下软件安装知识整理

    一.软件包安装分类源码包二进制包(RPM包,系统默认包)源码包优点1.开源 可以自由选择所需的功能    软件是编译安装,适合自己系统,更加稳定,效率更高    卸载方便 缺点 安装过程步骤较多,容易 ...

  3. Android 中Jackson的简单使用

    第一步:下载Jackson的jar包http://pan.baidu.com/s/1qXHwtQ0 第二步:在gradle中导入jar包 第三步:创建ObjectMapper对象的单例 Jackson ...

  4. MyBatis配置Mapping,JavaType和JDBCType的对应关系,#与$区别

    Mybatis中javaType和jdbcType对应关系:JDBC Type Java TypeCHAR StringVARCHAR StringLONGVARCHAR  StringNUMERIC ...

  5. C# DataReader

    //1 连接字符串 string connectionString = "server=127.0.0.1;integrated security=true;database=MSPetSh ...

  6. 第12课 std::bind和std::function(3)_std::function可调用对象包装器

    1. std::function (1)首先是一个类模板,用于包装可调用对象.可以容纳除了类成员(函数)指针之外的所有可调用对象. (2)可以将普通函数,lambda表达式和函数对象类统一起来.尽管它 ...

  7. remmina从linux远程桌面连接windows失败解决方法

    删除如下文件,重新连接 rm ~/.freerdp/known_hosts

  8. (转)Java调用Weservice

    原文地址:http://www.cnblogs.com/jiangxu1989/p/6491483.html https://www.cnblogs.com/neughj/p/5145630.html ...

  9. 在django中,执行原始sql语句

    extra()方法 结果集修改器,一种提供额外查询参数的机制 使用extra: 1:Book.objects.filter(publisher__name='广东人员出版社').extra(where ...

  10. 什么是Apache Flink

    大数据计算引擎的发展 这几年大数据的飞速发展,出现了很多热门的开源社区,其中著名的有 Hadoop.Storm,以及后来的 Spark,他们都有着各自专注的应用场景.Spark 掀开了内存计算的先河, ...