关于ES6的六个小特性(二)


Posted in Javascript onFebruary 20, 2017

前言

Javascript 团体的每个人都喜欢新的API,语法更新以及特性,它们提供了更好的,更智能,更有效的方式以完成重要的任务。

继上一篇的 《简单谈谈ES6的六个小特性》,这次我再分享6个可以减少代码和最大化效率的方法。

1.Object Shorthand

新的对象声明方法允许我们可以不声明对象的 key :

var x = 12;
var y = yes;
var z = {one:'1',two:'2'};

// The old way
var obj = {
 x:x,
 y:y,
 z:z
}
// The new way
var obj = {x,y,z};

2.Method Properties

避免 function 关键字声明函数:

var davidwalsh = {
 makeItHappen(param){
 // do stuff
 }
}

必须承认去除掉 function 关键字确实使代码简洁、更好维护。

3.Blocks vs Immediately Executed Functions

下面创建立即执行方法的模式有点难看:

(function(){
 // do stuff
})();

通过ES6我们可以通过 {} 和 let 来创建块级作用于,完成立即执行函数的作用:

{
 let j = 12;
 let divs = document.querySelectorAll('div');

 // do stuff
}

j; // ReferenceError: j is not defined...

如果在 Block 内部声明函数,它将会被外部访问到。但你如果使用 let 关键字声明函数自变量,将不使用括号的情况下实现 IEF 的功能。

4. for loops and let

因为在JS里面会存在变量提升,我们经常会在作用域前面声明一些”无用”的迭代变量,例如(for var x = …)。ES6 使用 let 解决了此恼人的问题:

for(let x = 0; x < len; i++){
 //do stuff
}

x; // ReferenceError: x is not defined

不久以后 let 会被应用的更多。

5.get and set for Classes

class Cart{
 constructor(total){
 this._total = total;
 }
 get total(){return this._total;}
 set total(v){this._total = Number(v);}
}

var cart = new Cart(100);

cart.total // 100

能为属性设置 get、set 是这部分最棒的。不需要使用函数来进行特殊的设定?当执行 obj.prop = {value} 时,一切都会自动执行。

6.startsWith,endsWith and includes

"MooTools".startsWith("Moo"); // true;
"MooTools".startsWith("moo"); // false;

"MooTools".endsWith("Tools"); // true;

"MooTools".includes("oo"); // true;

注:includes 方法兼容性还是很多,曾有一个线上bug,就是因为不支持此方法导致的。

原文:https://davidwalsh.name/es6-features-ii/amp

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

Javascript 相关文章推荐
提交表单时执行func方法实现代码
Mar 17 Javascript
非html5实现js版弹球游戏示例代码
Sep 22 Javascript
Javascript中引用示例介绍
Feb 21 Javascript
jQuery 鼠标经过(hover)事件的延时处理示例
Apr 14 Javascript
Javascript判断文件是否存在(客户端/服务器端)
Sep 16 Javascript
jQuery解决浏览器兼容性问题案例分析
Apr 15 Javascript
AngularJS入门教程之REST和定制服务详解
Aug 19 Javascript
jQuery上传多张图片带进度条样式(DEMO)
Mar 02 Javascript
Javascript 一些需要注意的细节(必看篇)
Jul 08 Javascript
iframe与主框架跨域相互访问实现方法
Sep 14 Javascript
VUE-cli3使用 svg-sprite-loader
Oct 20 Javascript
详解小程序不同页面之间通讯的解决方案
Nov 23 Javascript
JavaScript 总结几个提高性能知识点(推荐)
Feb 20 #Javascript
JS批量替换内容中关键词为超链接
Feb 20 #Javascript
网页中右键功能的实现方法之contextMenu的使用
Feb 20 #Javascript
使用contextMenu插件实现Bootstrap table弹出右键菜单
Feb 20 #Javascript
Angular.js跨controller实现参数传递的两种方法
Feb 20 #Javascript
Bootstrap table右键功能实现方法
Feb 20 #Javascript
BootstrapTable refresh 方法使用实例简单介绍
Feb 20 #Javascript
You might like
实现分十页分向前十页向后十页的处理
2006/10/09 PHP
vs中通过剪切板循环来循环粘贴不同内容
2011/04/30 PHP
PHP制作百度词典查词采集器
2015/01/29 PHP
使用URL传输SESSION信息
2015/07/14 PHP
JavaScript Event学习第五章 高级事件注册模型
2010/02/07 Javascript
node.js [superAgent] 请求使用示例
2015/03/13 Javascript
jQuery实现表格展开与折叠的方法
2015/05/04 Javascript
用JavaScript获取页面文档内容的实现代码
2016/06/10 Javascript
使用BootStrap实现标签切换原理解析
2017/03/14 Javascript
mui 打开新窗口的方式总结及注意事项
2017/08/20 Javascript
jquery之基本选择器practice(实例讲解)
2017/09/30 jQuery
对Angular中单向数据流的深入理解
2018/03/31 Javascript
JS集合set类的实现与使用方法示例
2019/02/01 Javascript
swiper4实现移动端导航切换
2020/10/16 Javascript
js脚本中执行java后台代码方法解析
2019/10/11 Javascript
vue 微信分享回调iOS和安卓回调出现错误的解决
2020/09/07 Javascript
python使用递归解决全排列数字示例
2014/02/11 Python
使用Python编写基于DHT协议的BT资源爬虫
2016/03/19 Python
使用APScheduler3.0.1 实现定时任务的方法
2019/07/22 Python
在VS2017中用C#调用python脚本的实现
2019/07/31 Python
python编写猜数字小游戏
2019/10/06 Python
Python实现结构体代码实例
2020/02/10 Python
python上传时包含boundary时的解决方法
2020/04/08 Python
CSS3——齿轮转动关键代码
2013/05/02 HTML / CSS
YOINS官网:时尚女装网上购物
2017/03/17 全球购物
护理职业应聘自荐书
2013/09/29 职场文书
遥感技术与仪器求职信
2014/02/22 职场文书
竞聘书格式及范文
2014/03/31 职场文书
推广普通话演讲稿
2014/05/23 职场文书
小区门卫的岗位职责
2014/09/26 职场文书
2014年酒店年度工作总结
2014/12/10 职场文书
2015年初中生自我评价范文
2015/03/03 职场文书
可可西里观后感
2015/06/08 职场文书
运动会广播稿200字
2015/08/19 职场文书
Python进行区间取值案例讲解
2021/08/02 Python
用Python爬取英雄联盟的皮肤详细示例
2021/12/06 Python