一、现在还有很多浏览器不能直接使用es6语法。特别是手机端的一些低版本的浏览器。都需要用bale转换一下。

但是目前流行的框架中(vue,react,angular)。都有自己的脚手架,都能用webpack转换下。或者直接自己配置webpack , fis3,nowa 等转换。

照样不是美滋滋。

二、属性的简洁写法 

//1.属性简洁表示语法
var foo = 'bar';
var obj = {foo};
console.log(obj);
//创建对象的函数
function createOjb(x = 1,y = 1){ //x = 1, y = 1; 参数的默认值
return {
x,y
}
}
var newObj = createOjb();
console.log(newObj); //{x:1,y:1}
var birthDate = '2017/8/12'
//2 方法的简写
var person = {
name:'绿巨人',
age:'200岁',
birthDate,
say(){
console.log(this.name); //等同于 say:function(){ console.log(this.name)};
}
}
person.say(); // 绿巨人
//in 方法
var msg = {
hello:'helloValue',
world:'worldValue'
}
console.log('hello' in msg,'helloValue' in msg);
// true,false; => 判断某个键值是在某个对象里面
//commonJS 模块化输出
function Obj(methods){
this.methods = methods || {};
}
Obj.prototype.getItem = function(key){
return key in this.methods ? methods[key] : null;
}
Obj.prototype.setItem = function(key,value){
this.methods[key] = value;
}
var obj = new Obj();
//module.exports = {obj};
//4.注意点 :简洁写法的属性名总是字符串,这会导致一些看上去比较奇怪的结果。

三、属性表达式

//属性名表达式
// 1. 对象添加属性的两种方式
var newObj = new Object();
newObj.name = 'html';
newObj['age'] = '20岁';
//对象字面量的方式 se5 中字面量方式下 属性名字只能用 字符串形式。不能用 ['name']
var newObj1 = {
name:'css',
age:'30岁'
}
//SE6
var newObj2 = {
['name']:'js',
['a' + 'ge']:'40岁',
['hello world']:'say hello world',
['say' + ' hi'](){
console.log(this['hello world'])
}
}
console.log(newObj2.name); // jss
console.log(newObj2['hello world']); // say hello world
newObj2['say hi'](); // say hello world
//!!!注意 属性名表达式是不能喝属性简写一起使用的
var objKey = {a:1};
var newObj3 = {
[objKey]:'我是一个对象'
}
console.log(newObj3); // {[object object]:'我是一对象'}
console.log(newObj3[{a:1}]); // 我是一个对象
console.log(newObj3['object object']); // undefined 是不是很奇怪啊

四、Object.is()

//Object.is();
//1.es5中
console.log(+0 === -0); // true
console.log(NaN === NaN); //false
//2.es6中
console.log(Object.is(+0,-0)); //false
console.log(Object.is(NaN,NaN)); //true
//在ES5中部署Object.is(); 方法
Object.defineProperty(Object,'is',{
value(x,y){
if(x === y){
return x !== 0 || 1/x === 1/y;
}
//针对NaN的情况
return x !== x && y !== y;
},
configurable:true,
enumerable:false,
writable:true
})

五、Object.assign()

 //Object.assign();  对象的合并  熟悉jquery 的人 var defaults = {a : 1} $.extend({},{},defaults || //{});
var target = {name:'es6'};
var target1 = {age:'5年'};
var target2 = {name:'es7'};
var target3 = {sex:'body'};
var defaults = {};
Object.assign(defaults,target,target1,target2,target3);
console.log(defaults); // {name: "es7", age: "5年", sex: "body"}
//从上面的defaults 的值可以看出 后面的属性会覆盖前面的属性。跟$.extend({} ,defaults || {});
// 一个道理
defaults.name = 'es8';
console.log(defaults); //{name: "es8", age: "5年", sex: "body"}
console.log(target2); //{ name:"es7"}
/*
!!! 注意 :: => 由此可以看出 Object.assign(); 是一个深拷贝的方法
!!!!!! (前提是目标某个原对象中没有对象属性)
ex:target = {
family:{
child:'七七'
}
}
目标对象属于对象属性时。就是浅拷贝啦。 跟 $.extend(true,{} , defaults || {}); 方法有区别。加了true 对象属性也进行深拷贝
*/
var tar = {
family:{
child:'七七'
}
}
var defaults1 = { };
Object.assign(defaults1,tar);
console.log(defaults1); // { family:{child:"七七"}};
defaults1.family.child = "琪琪";
console.log(defaults1); // { family:{child:"琪琪"}};
console.log(tar); // { family:{child:"琪琪"}};
//注意点2
// :: !!! Ojbect.assign() 方法只能克隆原对象。不能够克隆其继承的属性。
function cloneObject(obj){
let originProto = Object.getPrototypeOf(obj);
return Object.assign(Object.create(originProto), obj);
}
// Object.create() 方法是对其原型

六、属性的可枚举性

 //对象的可枚举性
var objEn = {};
Object.defineProperty(objEn,'foo',{
value:'不可枚举',
configurable:true,
enumerable:false,
})
console.log(Object.getOwnPropertyDescriptor(objEn,'foo'));
//{value: "不可枚举", writable: false, enumerable: false, configurable: true}
/*
描述对象的enumerable属性,称为”可枚举性“,如果该属性为false,就表示某些操作会忽略当前属性。
ES5 有三个操作会忽略enumerable为false的属性。
for...in循环:只遍历对象自身的和继承的可枚举的属性
Object.keys():返回对象自身的所有可枚举的属性的键名
JSON.stringify():只串行化对象自身的可枚举的属性
ES6 新增了一个操作Object.assign(),会忽略enumerable为false的属性,只拷贝对象自身的可枚举的属性。
*/

七、属性的遍历

//属性的遍历
var ojbEach = {
name:'es8',
age:'100年'
}
Object.defineProperty(ojbEach,'bar',{
value:'不可枚举',
enumerable:false,
writable:true,
configurable:true
})
//方法1 for in 循环遍历对象自身的和继承的可枚举属性(不含 Symbol 属性)。
for(var key in ojbEach){
console.log(ojbEach[key]); // es8 100年
}
//方法2 Object.keys(); 返回一个数组,包括对象自身的(不含继承的)所有可枚举属性(不含 Symbol 属性)。
var objArr = Object.keys(ojbEach); //
console.log(objArr); // ["name", "age"]
/*
方法3 Object.getOwnPropertyNames 返回一个数组,包含对象自身的所有属性(不含 Symbol 属性,但是包括不可枚举属性)。
*/
var objEnArr = Object.getOwnPropertyNames(ojbEach);//
console.log(objEnArr); //["name", "age", "bar"]
//方法4 Object.getOwnPropertySymbols(obj) 返回一个数组,包含对象自身的所有 Symbol 属性。
/*方法5 Reflect.ownKeys返回一个数组,包含对象自身的所有属性,不管属性名是 Symbol 或字符串,也不管是否可枚举。
*/

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

  1. es6对象的扩展

    对象(object)是 JavaScript 最重要的数据结构之一. object 在es6中新增了很多便利的方法 在es6中允许直接写入变量和方法的名称直接作为对象的属性 let x =1 ,y=2 ...

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

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

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

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

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

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

  5. ES6 对象的扩展(下)

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

  6. ES6 对象的扩展(上)

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

  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. 2.3.2 EditText(输入框)详解

    本节引言: 上一节中我们学习了第一个 UI控件TextView(文本框),文中给出了很多实际开发中可能遇到的一些需求 的解决方法,应该会为你的开发带来便利,在本节中,我们来学习第二个很常用的控件Edi ...

  2. Android学习笔记--通过wifi向服务器端发送数据

    (转自http://www.cnblogs.com/zhxiang/archive/2011/07/21/2112825.html) 客户端程序: 1 2 3 4 5 6 7 8 9 10 11 12 ...

  3. requests sslerror

    比较烦人的情况: 使用pip安装任何包和requests库请求https站都会提示SSL错误,试了网上很多方法,还是没解决,最后升级pip和requests库解决,特做记录. 升级pip curl h ...

  4. CentOS7下安装NVIDIA独立显卡驱动出现X service error问题解决方法

    问题症状: 最近在CentOS7下安装NVIDIA独立显卡驱动的过程中出现X service error问题,如下图所示: 解决方法: 0.到NVIDIA 官网上下载驱动文件(.run 格式) : N ...

  5. rabbitmq安装错误集

    1.安装依赖yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel openssl-devel unixODBC unixODBC- ...

  6. 学习笔记---gson

    1.gson变量定义注解 @SerializedName("char") private String charm;//mongo转化char 2.gson中json文件转化成类 ...

  7. 八,ESP8266 文件保存数据(基于Lua脚本语言)

    https://www.cnblogs.com/yangfengwu/p/7533845.html 应该是LUA介绍8266的最后一篇,,,,,,下回是直接用SDK,,然后再列个12345...... ...

  8. 解决Win10家庭版没有‘本地用户和组’问题

    今天偶然发现我的win10系统是家庭版,并且没有本地用户和组. 处理方法:将系统升至为win10专业版,然后下载microKMS_v17.02.14做的激活.参考网站 1.打开运行窗口,输入 gped ...

  9. DB2创建function(一)

    案例一:根据传入的值返回一个满足条件的值.适用于查询的字段(经过较复杂逻辑得出) CREATE FUNCTION "FAS"."GET_ALL_NAME" ( ...

  10. tomcat-在eclispe中配置远程调试

    在eclispe中新建web应用,名字叫webtest.里面只有一个HelloServlet.Web.xml配置如下. 修改tomcat的启动脚本startup.bat.复制startup.bat为s ...