对象(object)是 JavaScript 最重要的数据结构之一。

object 在es6中新增了很多便利的方法

在es6中允许直接写入变量和方法的名称直接作为对象的属性

let x =1 ,y=2

        const obj ={x,y}

        console.log(obj)
//{x: 1, y: 2}

这种写法等同于

let x = 1,y = 2

        const obj = {
'x':x,
'y':y
}

方法同理

        const obj2 = {
methods() {
return {
x,
y
}
}
}
const obj3 = {
methods:function() {
return {
x,
y
}
}
} console.log(obj2.methods())
//{x: 1, y: 2}
console.log(obj3.methods())
//{x: 1, y: 2}

这种简洁写法在vue中用到的地方很多 比如导出和创建实例时等等

另外就是es6中允许对象的属性用表达式

        const item="item"
const obj4 ={
"item":"hello"
} console.log(obj4.item)
// hello
console.log(obj4[item])
// hello

但是属性名表达式和简洁表达法不能同时使用

会报错Uncaught SyntaxError: Unexpected token }或者干脆直接给你提示

如果你的key值传进去的是一个对象的话那么他的key会默认转换成一个字符串  “[object Object]”

        const item2 = {
a: 1
};
const item3 = {
b: 2
}; const obj5 = {
[item2]: 'value',
[item3]: 'value'
}; console.log(obj5)
// {[object Object]: "value"}

对象的方法里边有一个name属性可以点出来  用上边的例子说明

const obj5 = {
[item2]: 'value',
[item3]: 'value',
con(){}
}; console.log(obj5)
// {[object Object]: "value"}
console.log(obj5.con.name)
//con

返回的name是一个字符串

这个在con声明的时候也是声明的一个字符串 :function(){ XXX}这样

阮一峰老师的博客里边讲到  对象的每个属性都有一个描述对象(Descriptor)

用来控制该属性的行为。Object.getOwnPropertyDescriptor方法可以获取该属性的描述对象。

他在博客里边讲了enumerable这个特性  是指可枚举性  如果这个为false的话   该对象就不能够被遍历

那么另外的三个属性都是什么意思呢

value这个肯定都知道就不说了

这个writable  这个特性是指属性的是否只读   如果这个属性被更改为false的时候这个属性的值  是指能被读取而不能被修改的

另外一个configurable这个特性是指属性的基础操作   如果这个属性为false的时候  他会告诉js引擎  不可以删除delete这个属性和修改update这个属性

Object.keys(obj)

这个方法可以返回所有的可枚举的属性的key值,比较实用

super关键字

这个关键字只可以在对象的方法里边使用  他会指向对象的原型对象的属性,如果不是用在对象的方法里边就会报错

对象的扩展运算符   ...(三个点)

这个运算符和数组的的差不多  不同的是 他的右边赋值对象必须是一个对象 不能是undefind或者null  否则就会报错

let { x, y, ...z } = null; // 运行时错误
let { x, y, ...z } = undefined; // 运行时错误

但是他可以直接  ...undefind

{...undefined} // {}

会返回一个空对象

另外 对象的扩展运算符不一定要放在最后,可以放在前边,但是同名属性会被覆盖掉

这个在平时项目中的赋值里边应该会很遍历 不用再很冗余的写一大堆的赋值

最后  扩展运算符里边也是支持三元运算符的   粘贴一个例子

const obj = {
...(x > 1 ? {a: 1} : {}),
b: 2,
};

以上是对es6对象的扩展的理解  如有不足之处希望批评指正

es6对象的扩展的更多相关文章

  1. Es6对象的扩展和Class类的基础知识笔记

    /*---------------------对象的扩展---------------------*/ //属性简写 ,属性名为变量名, 属性值为变量的值 export default functio ...

  2. ES6对象的扩展及新增方法

    1.属性的简洁表示法 ES6允许直接写入变量和函数,作为对象的属性和方法.这样的书写更加简洁. const foo = 'bar'; const baz = {foo}; baz//{foo:'bar ...

  3. web前端之es6对象的扩展

    1.属性的简洁表示法 2.属性名表达式 表达式作为对象的属性名 3.方法的 name 属性 例如:函数的name 属性,返回函数名. 4.Object.is() ES 比较两个值是否相等,只有两个运算 ...

  4. ES6 对象的扩展(下)

    属性的可枚举性 对象的每个属性都有一个描述对象(Descriptor),用来控制该属性的行为.Object.getOwnPropertyDescriptor方法可以获取该属性的描述对象. var ob ...

  5. ES6 对象的扩展(上)

    属性的简介表示法 允许直接写入变量和函数作为对象的属性和方法,这样的书写更简洁. function f( x, y ) { return { x, y }; } // 等同于 function f( ...

  6. es6 对象的扩展

    一.现在还有很多浏览器不能直接使用es6语法.特别是手机端的一些低版本的浏览器.都需要用bale转换一下. 但是目前流行的框架中(vue,react,angular).都有自己的脚手架,都能用webp ...

  7. ES6 对象的扩展 Object.assign()

    Object.assign方法用于对象的合并,将源对象(source)的所有可枚举属性,复制到目标对象(target). const target = { a: 1 }; const source1 ...

  8. ES6 对象的扩展 Object.is()

    ES5 比较两个值是否相等,只有两个运算符:相等运算符(==)和严格相等运算符(===).它们都有缺点,前者会自动转换数据类型,后者的NaN不等于自身,以及+0等于-0. ES6 提出“Same-va ...

  9. ES6对象扩展

    前面的话 随着JS应用复杂度的不断增加,开发者在程序中使用对象的数量也在持续增长,因此对象使用效率的提升就变得至关重要.ES6通过多种方式来加强对象的使用,通过简单的语法扩展,提供更多操作对象及与对象 ...

随机推荐

  1. Service Worker 离线无法缓存Post请求的问题解决

    许多非REST API甚至可以用于读取数据的POST请求:典型的例子是graphql.soap和其他rpcpapi.但是,Post请求不能在一个现成的渐进式Web应用程序中缓存和脱机使用.浏览器的缓存 ...

  2. 前端使用crypto.js进行加密

    前端使用crypto.js进行加密 https://www.cnblogs.com/lz2017/p/8046816.html   最近我在前端使用Cookies保存密码的时候需要前端来进行加密工作, ...

  3. 【Windows 7】发现一个奇怪的现象

    最近在Windows7-32位操作系统上发现一个奇怪的现象,不知道64位操作系统上会不会发生这个现象.这个现象就是:如果系统上的一个或多个账户没有设置密码,那么在此条件下终止winlogon.exe进 ...

  4. New Journey--工作五年所思所感小记

    正式参加工作满五年了,2013年7月9日走入游戏行业.之前就计划着应该提笔写点什么留下来,但当日子真的到了,竟是不知说些什么了.14年年中的时候我曾写过一篇工作一年的总结,现在回头读起来,还真是别有一 ...

  5. 试用 Angular v6 的 Ivy compiler

    “Ivy” 是 Angular v6 的新一代渲染器.从 v6.0.0-beta.1 开始,Ivy 已经作为体验 API 发布. 作为下一代的 Angular 的视图引擎,重点在于彻底缩减代码尺寸并增 ...

  6. 走进HashMap

    1.手写实现HashMap 2.解析代码并阐述HashMap1.7到1.8的变化 3.HashMap的遍历方式 4.HashMap与HashSet,Hashtable,ConcurrentHashMa ...

  7. c博客作业01--顺序、分支结构

    1.本章学习总结 1.1思维导图 1.2本章的学习体会及代码量学习体会 1.2.1学习体会 本周学习的感受:原先基础是0的,所以本周学习起来并不是很轻松,有很多知识运用的 不是很熟,但是基本的知识是能 ...

  8. SpringBoot整合StringData JPA

    目录 SpringBoot整合StringData JPA application.yml User.class UserRepository.java UserController SpringBo ...

  9. 在虚拟机上的ubuntu 1.6 系统中sudo apt-get失败的问题

    在虚拟机上sudo apt-get update 失败.可能是网络dns问题,把nameserver \设为你路由器的内网ip地址就没事了; 详细: 1/打开sudo gedit /etc/resol ...

  10. MyBatis 生命周期

    一.SqlSessionFactoryBuilder SqlSessionFactoryBuilder是利用XML或是Java编码获得资源来构建SqlSessionFactory的,通过他可以构建多个 ...