ES6 - 对象
ES6为对象带来的新特性。
对象传统的写法:
let person={
'name':'Lily',
'say':function(){
alert('hello!');
}
}
1、ES6中写法更简便
对象属性:
var name='Lily';
var age='13';
var person={name,age};
console.log(person) //{name:'Lily',age:'13'}
对象方法:
var person={
say(){ //省略了function
alert('hello');
}
}
2、属性名可以为表达式
当用字面量定义(用大括号{}定义)一个对象时,属性名或方法名可以是表达式。
var f='first';
var n='Name';
var s='say';
var h='Hello';
var person={
[f+n]:'Zhang',
[s+h](){
return 'hello world';
}
}
console.log(person.firstName) //'Zhang'
console.log(person.sayHello()) //'hello world'
3、ES6为对象新增的函数
(1)Object.is() :比较两个值是否严格相等。
首先我们来区分什么是严格相等和抽象相等:
var str='12';var num=12;
- 严格相等 (要求变量类型也相同)
str===num //false
- 抽象相等 (将两边变量转化为同一类型再比较)
str==num //true
对于新增函数Object.is():Object.is(str,num) //false
(2)Object.assign() :将源对象的属性值赋值到目标对象。
let target={'a':1};
let origin={'b':2,'c':3};
Object.assign(terget,orgin);
console.log(target) //{a:1,b:2,c:3}
当源对象有与目标对象相同名字的属性时,会覆盖目标对象上的属性(后者覆盖前者);
Object.assign()可以接受多个源对象参数:
let origin2={'d':4,'a':5};
Object.assign(terget,orgin,orgin2);
console.log(target) //{a:5,b:2,c:3,d:4}
(3)Object.getPrototypeOf() :获取一个对象的prototype属性。
function Person={
}
Person.prototype={
say(){ console.log('hello'); }
};
let Lily=new Person();
Lily.say(); //hello
获取Lily的prototype属性: Object.getPrototypeOf(Lily) //say:function(){ ...}
可以实现继承:
(4)Object.setPrototypeOf() : 设置对象的prototype属性
以(3)中的例子来说明:
Object.setPrototypeOf(Lily,{
say(){ console.log('hi') }
})
Lily.say() //hi
_______________________________
参考:公众号 web前端教程
ES6 - 对象的更多相关文章
- ES6 对象解构
ES6 对象解构 第一眼看到,什么鬼? const { body } = document `` 其实等于: const body = document.body ``` http://es6.rua ...
- ES6对象扩展
前面的话 随着JS应用复杂度的不断增加,开发者在程序中使用对象的数量也在持续增长,因此对象使用效率的提升就变得至关重要.ES6通过多种方式来加强对象的使用,通过简单的语法扩展,提供更多操作对象及与对象 ...
- ES6对象及ES6对象简单拓展
ES6对象和传统的JS比较起来支持简写,比如说属性简写方法简写,还支持name属性,可以通过他迅速得到函数属性名表达式(如果是用bind方法创造的函数name属性会返回bound加上原函数的名字,Fu ...
- es6对象字面量增强
相对于ES5,ES6的对象字面量得到了很大程度的增强.这些改进我们可以输入更少的代码同时语法更易于理解.那就一起来看看对象增强的功能.对象字面量简写(Object Literal Shorthand) ...
- es6对象的扩展
对象(object)是 JavaScript 最重要的数据结构之一. object 在es6中新增了很多便利的方法 在es6中允许直接写入变量和方法的名称直接作为对象的属性 let x =1 ,y=2 ...
- ES5和ES6对象导出和导入(转载,待整理)
1.import ... form...替代 require() //不接收对象 require:require('s.css'); //(es5) improt 's.css' //(es6) // ...
- es6对象内函数的两种写法
es6对象内函数一般有两种写法: var person1 = { name: "p1", sayThis() { console.log(this); } }; var perso ...
- es6 对象浅拷贝的2种方法
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- ES6(对象扩展)
ES6(对象(object)新增特性) 1.简介表示法 o,k 为属性:这种为无方法的情况. 这种为有方法. 2.属性表达式 ES6中,[a]就是 b . 3.新增API 1.数组也是引用类型 2.O ...
- ES6 对象拓展方法
一,ES6 对象拓展方法 ES6为对象提供了一些拓展方法,下面列举几个比较常见的对象拓展方法.
随机推荐
- async = require('async')
var mongoose = require('mongoose'), async = require('async'); mongoose.connect('localhost', 'learn-m ...
- 神奇的NOIP模拟赛 T1 LGTB 玩扫雷
LGTB 玩扫雷 在一个n m 的棋盘上,有位置上有雷(用“*” 表示),其他位置是空地(用“.” 表示).LGTB 想在每个空地上写下它周围8 个方向相邻的格子中有几个雷.请帮助他输出写了之后的棋盘 ...
- Java 类的一般特征
1. 创建类的对象时的内存结构 用图来解释: 使用new 创建 a1 时,成员变量的值都是初始默认值. 然后显式的改变其属性的值. 创建a3 时,a3 是直接指向 a1, 即a3 = a1, 两个对象 ...
- namenode 无法启动之每次开机需要重新格式化-tmp
最近遇到了一个问题,执行start-all.sh的时候发现JPS一下namenode没有启动 每次开机都得重新格式化一下namenode才可以 其实问题就出在tmp文件,默 ...
- 常错-UIScrollView中得图片不能被拖动
经常在开发中,发现自己UIScrollView里面的图片不能被拖动 在这里做个备忘,第一种可能是contentSize没有设置,第二种可能是contentSize设置的太小了. 测试后发现,与user ...
- 给伪类设置z-index= -1;
.column{ position: relative; float: left; padding: 30px 0; width: 25%; z-index: 0; background-color: ...
- 将Ajax 中数组转换成字符串 封装成类
<?php class Ajax{ //ajax调用的方法 //sql是要执行的语句 //$type是SQL语句的类型,0代表增删改,1代表查询 //$db代表要操作的数据 public fun ...
- scanf和scanfs的区别
scanf()函数是标准C中提供的标准输入函数,用以用户输入数据 scanf_s()函数是Microsoft公司VS开发工具提供的一个功能相同的安全标准输入函数,从vc++2005开始,VS系统提供了 ...
- poj2777 线段树
//Accepted 4768 KB 391 ms //线段树,延时标记的应用 //对于每一段,用一个int表示被着色的情况,change标记该段的颜色是否发生整体的改变,即这一段 //用没用被全部涂 ...
- Ubuntu 14.10 下NodeJS Cannot find module 'npmlog'
在安装brunch的时候npm install -g brunch发现如下问题: Error: Cannot find module ‘npmlog’ at Function.Module._reso ...