因为工作的原因,实际上读书的时间很少,读【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。小说散文就已经够折腾了,静下心读技术方面【本文首发于唐霜的博客】原创内容,盗版必究。的书就更困难。不过公司有学习经费,自己的【访问 www.tangshuang.net 获取更多精彩内容】【原创内容,转载请注明出处】今年还有一半没有花出去,眼看已经第四季度转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】了,不花就便宜了公司,所以赶紧买了一些书【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】,买回来不读又浪费,就先把阮一峰《ES6著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】标准入门(第2版)》先读完。
【访问 www.tangshuang.n转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。et 获取更多精彩内容】【原创不易,请尊重版权】原创内容,盗版必究。
阮一峰写的东西就是为了通俗易懂,不去纠结【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】于字眼。这本书也主要把ES6和ES5不同本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】的地方列出来进行阐述,不是Javascr转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】ipt的入门书籍。虽然大部分我都有所接触【原创不易,请尊重版权】【本文受版权保护】,但是系统的学习还是有必要的,这样才能有【本文首发于唐霜的博客】未经授权,禁止复制转载。全局观。平时下班回家就看几十页,周末的时原创内容,盗版必究。转载请注明出处:www.tangshuang.net候啃完了。接下来,就结合自己的一些开发经著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。验,谈谈自己觉得ES6带给我的最吸引人的【访问 www.tangshuang.net 获取更多精彩内容】原创内容,盗版必究。地方。
原创内容,盗版必究。本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。废掉老版作用域的节奏
Javascript里function是【访问 www.tangshuang.net 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。一级成员,ES5的时候,要么是全局作用域本文版权归作者所有,未经授权不得转载。【本文受版权保护】,要么是函数级作用域,都用关键字var进【转载请注明来源】未经授权,禁止复制转载。行作用域里面的变量声明。但是到了ES6,【关注微信公众号:wwwtangshuangnet】【本文首发于唐霜的博客】除了全局变量在局部作用域仍然有效这点,其【原创内容,转载请注明出处】【作者:唐霜】他方面的理解全给废了,不升级知识,根本没转载请注明出处:www.tangshuang.net原创内容,盗版必究。法装逼下去。
本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。全局变量
首先,解释一下全局作用域对我来说很重要。
转载请注明出处:www.tangshua【转载请注明来源】转载请注明出处:www.tangshuang.netng.net【版权所有】唐霜 www.tangshu【本文受版权保护】原创内容,盗版必究。ang.net【版权所有,侵权必究】原创内容,盗版必究。在开发php的时候,就没有这个概念,在J【关注微信公众号:wwwtangshuangnet】【关注微信公众号:wwwtangshuangnet】avascript里面,我们这样做:
【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】var a = 1;function autoinc() {
a ++;
}
autoinc();
console.log(a);
在函数autoinc()中a这个全局变量原创内容,盗版必究。【原创不易,请尊重版权】是有效的,但在php中,函数里面必须用g【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。lobal去找到全局变量:
【版权所有】唐霜 www.tangshu【本文首发于唐霜的博客】【转载请注明来源】ang.net转载请注明出处:www.tangshua【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】ng.netglobal $a;
$a = 1;
function autoinc() {
global $a;
$a ++;
}
autoinc();
echo $a;
你可以看到,在函数外面的区域,也要用gl【未经授权禁止转载】【本文首发于唐霜的博客】obal去声明$a这个全局变量,func本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。tion外跟function内并没有全局转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。与局部的概念,大家都是局部,并不共享变量【版权所有,侵权必究】【版权所有】唐霜 www.tangshuang.net,只有用global声明之后才能在其他作【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.net用域内共享这个变量。
【原创不易,请尊重版权】【关注微信公众号:wwwtangshua【版权所有,侵权必究】未经授权,禁止复制转载。ngnet】转载请注明出处:www.tangshua【转载请注明来源】转载请注明出处:www.tangshuang.netng.net【版权所有】唐霜 www.tangshu本文版权归作者所有,未经授权不得转载。【转载请注明来源】ang.net基于这一点,我认为Javascript在【本文受版权保护】未经授权,禁止复制转载。全局与局部的安排上更加符合普通人思维。
【原创不易,请尊重版权】原创内容,盗版必究。未经授权,禁止复制转载。但是到了ES6这个茬,大部分风格规范都推著作权归作者所有,禁止商业用途转载。【转载请注明来源】荐使用const来声明一个全局变量,意思转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。就是说,如果你在全局作用域去声明一个变量【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】,应该是想在所有作用域范围内共享它,那么著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.net它就应该保持不变,否则会导致在不同作用域【转载请注明来源】转载请注明出处:www.tangshuang.net得到非预期的结果。
本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】这么一来,实际上有取消全局变量的意思,c【原创内容,转载请注明出处】未经授权,禁止复制转载。onst声明的是不可改变的常量,相当于只本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】是一个别名而已。当然,ES6标准并没有这未经授权,禁止复制转载。转载请注明出处:www.tangshuang.net么要求,var声明全局变量仍然是有效的。
【版权所有】唐霜 www.tangshu【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。ang.net转载请注明出处:www.tangshua【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】ng.net未经授权,禁止复制转载。【原创不易,请尊重版权】块级作用域与let声明
用花括号处理的作用域就是块级作用域,比如未经授权,禁止复制转载。【版权所有,侵权必究】for/while循环语句,if判断语句转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。,甚至莫名其妙写一个{},在这个作用域内【作者:唐霜】【本文受版权保护】,用let声明变量,出了作用域就被销毁。
未经授权,禁止复制转载。未经授权,禁止复制转载。var i = 99;for(let i = 10;i --;) {
console.log(i); // 循环内的i值}console.log(i); // 99
在这本书里面提到,Airbnb推荐,你就著作权归作者所有,禁止商业用途转载。【本文受版权保护】不要用var声明变量,全部用const/【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。let代替,const声明全局的不变的常未经授权,禁止复制转载。原创内容,盗版必究。量,let声明块级的变量……
【访问 www.tangshuang.n【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】et 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。看到这里的时候,我都有点崩溃了。它的意思【本文受版权保护】原创内容,盗版必究。是:
未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshu【未经授权禁止转载】【原创内容,转载请注明出处】ang.net【本文受版权保护】- 把整个全局当做一个块级作用域,把整个全局本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。想象为放在一个花括号中间的代码 【本文受版权保护】转载请注明出处:www.tangshua【作者:唐霜】【版权所有,侵权必究】ng.net【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。ngnet】
- 把函数也当做一个块级作用域,函数里面根本著作权归作者所有,禁止商业用途转载。未经授权,禁止复制转载。用不到var(不考虑变量声明提升) 本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshua未经授权,禁止复制转载。【未经授权禁止转载】ng.net【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshuang.netang.net
如果是这样,相当于把var废掉,把fun本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。ction作用域废掉,把全局变量废掉,所【未经授权禁止转载】本文作者:唐霜,转载请注明出处。有真正可以变的变量都是let,那搞个鸡毛【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.net……
本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】幸好,这只是Airbnb这家公司的风格,著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshuang.netES6甚至ES7并没有任何一点迹象打算对【转载请注明来源】本文版权归作者所有,未经授权不得转载。var开刀,相反,我仍然觉得全局变量的使【未经授权禁止转载】原创内容,盗版必究。用是Javascript的一大特色。
本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】上面提到,“把函数也当做块级作用域”,这【本文受版权保护】【版权所有】唐霜 www.tangshuang.net种想法把函数从一等公民中踢出,和其他块级未经授权,禁止复制转载。【本文受版权保护】作用域地位平等,这也让我不能接受。Jav【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netascript的一大特色是函数,它不仅拥本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net有对象的本质属性,而且拥有转化为实际“类【关注微信公众号:wwwtangshuangnet】【未经授权禁止转载】”的功能,而且把它作为回调函数也是实现J【原创不易,请尊重版权】【本文首发于唐霜的博客】avascript异步操作的主要方式。如【作者:唐霜】【版权所有】唐霜 www.tangshuang.net果把函数降级,从配备上讲,应该将它的实例【转载请注明来源】本文作者:唐霜,转载请注明出处。化功能去除,虽然ES6直接提供了clas未经授权,禁止复制转载。原创内容,盗版必究。s,但它本质上还是函数的语法糖,函数的角【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。色不仅未被弱化,反而强化。
【未经授权禁止转载】【关注微信公众号:wwwtangshua【版权所有,侵权必究】【作者:唐霜】ngnet】【转载请注明来源】本文版权归作者所有,未经授权不得转载。所以,我认为在函数中,顶层变量仍然应该用【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。var进行声明,以此区别于以let声明的原创内容,盗版必究。【原创不易,请尊重版权】变量。
【访问 www.tangshuang.n【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】et 获取更多精彩内容】【原创不易,请尊重版权】字符串模板
这个先讲好了,字符串模板是什么意思?就是【原创内容,转载请注明出处】【版权所有,侵权必究】像PHP一样,可以在字符串里面用变量,只【版权所有】唐霜 www.tangshuang.net本文作者:唐霜,转载请注明出处。不过使用方法是要用${变量或表达式}这种方法括起来。
var a = `
<p>I am ${sex.man}, and not like ${sex.woman}</p>
<p>I want to know if 1+2 equals ${a + 2}</p>
`;
可以看到,字符串模板采用“将【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。字符串引起来,它和原来的Javascri【原创内容,转载请注明出处】【未经授权禁止转载】pt字符串有两大区别:
本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshu著作权归作者所有,禁止商业用途转载。【关注微信公众号:wwwtangshuangnet】ang.net- 可以换行 本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshua著作权归作者所有,禁止商业用途转载。【作者:唐霜】ng.net
- 可以引用变量/表达式 【转载请注明来源】【版权所有】唐霜 www.tangshu【原创内容,转载请注明出处】转载请注明出处:www.tangshuang.netang.net【作者:唐霜】
换行就不说了,以前我们要么使用+连接字符【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。串,要么使用\换行,现在通通不用了。
本文作者:唐霜,转载请注明出处。
引用变量就非常牛逼,你第一次使用这个字本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。符串模板的时候,把它显示在界面上,然后修【未经授权禁止转载】【关注微信公众号:wwwtangshuangnet】改变量的值,再显示到界面上,感觉是不是有著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。点hi~
解构赋值
我认为这是ES6最酷的地方,它不仅从某种【关注微信公众号:wwwtangshuangnet】【版权所有,侵权必究】意义上弥补了Javascript提取值的【本文受版权保护】原创内容,盗版必究。时候变量名和属性名(键名)对应的操作,更未经授权,禁止复制转载。【转载请注明来源】牛逼的地方是,它用超级简单的语法糖超越了【未经授权禁止转载】著作权归作者所有,禁止商业用途转载。大部分语言的解构赋值。
本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。【未经授权禁止转载】【关注微信公众号:wwwtangshua【本文首发于唐霜的博客】著作权归作者所有,禁止商业用途转载。ngnet】数组解构赋值
我们来看下php中的一种写法:
【版权所有,侵权必究】【访问 www.tangshuang.n未经授权,禁止复制转载。【本文首发于唐霜的博客】et 获取更多精彩内容】转载请注明出处:www.tangshua【原创内容,转载请注明出处】原创内容,盗版必究。ng.netlist($a,$b) = explode(',',$str);
但在Javascript中更加方便:
【原创内容,转载请注明出处】【本文受版权保护】【关注微信公众号:wwwtangshua【版权所有】唐霜 www.tangshuang.net原创内容,盗版必究。ngnet】原创内容,盗版必究。var [a,b] = str.split(',');
如果a,b之前已经声明了,那么这里连va【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。r都省了。你或许会觉得看上去好不到哪里去原创内容,盗版必究。【转载请注明来源】,但是我告诉你,在php里面,你必须去调本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.net用list这个函数,而在Javascri未经授权,禁止复制转载。【原创内容,转载请注明出处】pt呢?完全是赋值这个动作完成的。
【本文受版权保护】本文版权归作者所有,未经授权不得转载。对象解构赋值
更有用的,是对象的解构赋值,因为我们经常原创内容,盗版必究。本文作者:唐霜,转载请注明出处。会使自己的函数返回对象:
【作者:唐霜】本文作者:唐霜,转载请注明出处。// badfunction getA() {
return {
name : 'Mico',
age : 10
}}var a = getA();var name = a.name;var age = a.age;
// goodvar {name, age} = getA();
关于解构赋值的深层的东西,还需要你自己去著作权归作者所有,禁止商业用途转载。【作者:唐霜】读书,我只想说的是,看到这样的语法糖,我原创内容,盗版必究。【本文首发于唐霜的博客】TM真的忍不住想尖叫有没有,太爽了。
原创内容,盗版必究。【版权所有】唐霜 www.tangshu【访问 www.tangshuang.net 获取更多精彩内容】【转载请注明来源】ang.net未经授权,禁止复制转载。函数参数解构
更了不起的解构被用在函数的参数上。我们有本文作者:唐霜,转载请注明出处。【本文受版权保护】时会传入多个参数给函数,但是可惜的是,有【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。的时候你并不知道那些参数是不一定需要的。【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】以往我们必须在复杂参数解构中,传入一个对转载请注明出处:www.tangshuang.net【作者:唐霜】象,通过对象的属性去调用自己要的值,比如【版权所有】唐霜 www.tangshuang.net【关注微信公众号:wwwtangshuangnet】:
【关注微信公众号:wwwtangshua【版权所有,侵权必究】【未经授权禁止转载】ngnet】未经授权,禁止复制转载。未经授权,禁止复制转载。function curl(url,postData,headers) {} // 如果并不存在postData,我们不得不这样调用:curl('http://xxx',null,{cookies:'xxx'}); // 第二个参数其实是没有必要的
上面是我们最早的一种方式,为了实现我们的著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】想法,我们决定修改参数:
【版权所有,侵权必究】【原创不易,请尊重版权】function curl(url,options) {
// ...
if(options.postData) {}
if(options.headers) {}
// ...}curl('http://xxx',{
headers:{cookies:'xxx'}});
通过上面这种传入对象参数的方式,可以实现本文作者:唐霜,转载请注明出处。【本文首发于唐霜的博客】防止参数不必须传入的情况。
本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【转载请注明来源】【本文受版权保护】但是,来到ES6的时代,我们可以这样做:
本文作者:唐霜,转载请注明出处。【访问 www.tangshuang.n【未经授权禁止转载】【作者:唐霜】et 获取更多精彩内容】function curl({url,postData,headers}) {
return some_ajax({
url : url,
data : postData,
headers : headers
});}curl({
url : 'xxx',
headers : {
cookies: 'xxx'
}});
从上面可以看到,直接在定义函数的时候,利未经授权,禁止复制转载。【本文受版权保护】用函数参数也可以解构的特性,把参数写成{url,postData,headers}的形式,那么在调用函数的时候,传入一个对【作者:唐霜】转载请注明出处:www.tangshuang.net象作为参数,传入的参数会自动解构给声明时【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】候的那个对象。
本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua【转载请注明来源】【访问 www.tangshuang.net 获取更多精彩内容】ng.net{url}这种对象形式也是ES6新增的,【本文首发于唐霜的博客】【作者:唐霜】它的意思是
转载请注明出处:www.tangshua本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。ng.net著作权归作者所有,禁止商业用途转载。{url:url},第一个url是属性名,第二个url是变【本文受版权保护】【关注微信公众号:wwwtangshuangnet】量。如果在这之前没有声明第二个url变量未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。,那么会报错。
当然,除了使用对象这种方法,我们回到最前【本文受版权保护】【本文首发于唐霜的博客】面的function curl(url,postData,headers) {}。我们现在还可以这样调用:
curl(['xxx',,{cookies:'xxx'}]); // 注意,第二个元素为空
通过数组解构的方式把参数传过去,在不需要【版权所有】唐霜 www.tangshuang.net【本文受版权保护】传入的位置留空就可以了。
转载请注明出处:www.tangshua【转载请注明来源】【作者:唐霜】ng.net本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。ng.net这种用法,简直了!我都有种感动的流鼻涕的【版权所有,侵权必究】本文作者:唐霜,转载请注明出处。兴奋感。只可惜目前浏览器还没有广泛支持,未经授权,禁止复制转载。本文版权归作者所有,未经授权不得转载。我们需要babel的帮助……不好意思,又【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。扯到babel。
著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。【版权所有,侵权必究】默认值
习惯了php函数的默认值,写Javasc【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.netript函数的时候,有种香菇的冲动。然而【未经授权禁止转载】【本文首发于唐霜的博客】,当ES6来的时候,妈妈再也不用担心我的【转载请注明来源】未经授权,禁止复制转载。默认值,而且Javascript现在的默【原创内容,转载请注明出处】【作者:唐霜】认值,比php牛逼哄哄多了好吗。
未经授权,禁止复制转载。【作者:唐霜】著作权归作者所有,禁止商业用途转载。转载请注明出处:www.tangshua转载请注明出处:www.tangshuang.net【本文首发于唐霜的博客】ng.net函数的参数
function plus(x = 0,origin = 5) {
return origin + x;}var rs = plus(5);alert(rs);
这和php的用法一摸一样。
【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net【关注微信公众号:wwwtangshuangnet】ang.netfunction sum(x = 2,y = x) {
return x + y;}var rs = sum(5);alert(rs);
这就不一样了……点解y可以等于x?也就是转载请注明出处:www.tangshuang.net未经授权,禁止复制转载。说,在Javascript里,函数的参数原创内容,盗版必究。【未经授权禁止转载】默认值可以是声明过的变量,如果该默认值没有声明过,就报错,【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。因此,参数的变量名顺序也很重要。
本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】function sum(x = 2,y = x + 3) {
return x + y;}var rs = sum(6);alert(rs);
什么鬼?连表达式都可以作为默认值?是的,著作权归作者所有,禁止商业用途转载。【原创不易,请尊重版权】你没有瞎,只要在默认值运算的时候变量都是本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.net经过声明的就OK。
【原创内容,转载请注明出处】
放个大招:
function curl(url,{postData,headers = {cookies : 'xxx'}} = {}) {
return some_ajax({
url: url,
data: postData || {}
headers: headers || {}
});}curl('http://xxx');
这是什么鬼?给我一脸黑人头像……其实简单【本文受版权保护】【本文首发于唐霜的博客】,这里面有默认值的知识,也有解构赋值的知【本文受版权保护】著作权归作者所有,禁止商业用途转载。识,{postData,headers}【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。是解构赋值这一层,headers = {【转载请注明来源】原创内容,盗版必究。cookies: ‘xxx&未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】#8217;}是解构赋值的时候如果传入的【本文受版权保护】【本文首发于唐霜的博客】对象里没有headers这个属性,默认值【本文首发于唐霜的博客】未经授权,禁止复制转载。设为{cookies : ‘【本文受版权保护】【访问 www.tangshuang.net 获取更多精彩内容】xxx’},{postDat【作者:唐霜】【本文首发于唐霜的博客】a,headers} = {}是默认值设转载请注明出处:www.tangshuang.net【原创内容,转载请注明出处】置,也就是函数的第二个参数如果没有设置的【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。话,则设置为空对象。
【关注微信公众号:wwwtangshua【本文受版权保护】【原创不易,请尊重版权】ngnet】【原创不易,请尊重版权】【原创不易,请尊重版权】未经授权,禁止复制转载。它的整个默认值,解构赋值的过程大概是这样著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】:
本文版权归作者所有,未经授权不得转载。未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。本文版权归作者所有,未经授权不得转载。function curl(url,options = {}) {} // 第一层:不存在第二个实参的话,使用{}默认值function curl(url,{postData,headers}) {} // 第二层:如果存在第二个实参(默认值是{}也表示存在第二个实参),进行对象解构赋值function curl(url,postData,headers = {cookies: 'xxx'}) {} // 第三层:解构赋值的时候不存在headers,传入一个默认值
所以上面执行curl(‘xx【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】x’),因为没有第二个实参,【原创内容,转载请注明出处】【版权所有,侵权必究】所以实际上第二个参数默认值传入了{},所【访问 www.tangshuang.net 获取更多精彩内容】【本文首发于唐霜的博客】以函数体内postData是不存在的,是本文版权归作者所有,未经授权不得转载。【原创不易,请尊重版权】undefined。但是headers是著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。存在的,因为第二个参数传入了默认值,第二未经授权,禁止复制转载。【未经授权禁止转载】层的解构赋值无论如何都会进行,这个时候h【版权所有】唐霜 www.tangshuang.net【原创不易,请尊重版权】eaders的默认值就是{cookies【原创内容,转载请注明出处】【本文受版权保护】:’xxx’}了本文作者:唐霜,转载请注明出处。原创内容,盗版必究。。解构的时候也存在默认值,这个默认值不是原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。函数参数默认值,而是解构默认值,解构默认本文作者:唐霜,转载请注明出处。未经授权,禁止复制转载。值往下看。
【本文首发于唐霜的博客】本文作者:唐霜,转载请注明出处。解构默认值
解构的时候也可以设置默认值,按理应该在前未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。面讲,但是函数参数默认值更常见,有了上面【版权所有,侵权必究】本文版权归作者所有,未经授权不得转载。的引子,再来说解构默认值,简直直接说完就本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。可以了。
转载请注明出处:www.tangshua【转载请注明来源】【版权所有】唐霜 www.tangshuang.netng.net本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【原创不易,请尊重版权】var {x = 0,y = 1} = {x : 5};console.log(x,y);
而且解构默认值也遵循上面提到的默认值可以【版权所有】唐霜 www.tangshuang.net著作权归作者所有,禁止商业用途转载。是变量和表达式的规则,只要变量经过声明就【访问 www.tangshuang.net 获取更多精彩内容】未经授权,禁止复制转载。可以。
转载请注明出处:www.tangshua【未经授权禁止转载】【作者:唐霜】ng.net【原创不易,请尊重版权】原创内容,盗版必究。【转载请注明来源】这种东西,在我见过的语言里,就Javas著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。cript里面有,只能说我孤陋寡闻,第一【本文受版权保护】本文作者:唐霜,转载请注明出处。次看到,下巴都掉了。
未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】ngnet】…(扩展运算符)和for…of
在ES6里面,真的是活久见,如果10年前原创内容,盗版必究。未经授权,禁止复制转载。开始写Javascript,谁曾想到,一【本文受版权保护】【原创内容,转载请注明出处】下子出来这么多新东西,完全接受不了。你要【关注微信公众号:wwwtangshuangnet】著作权归作者所有,禁止商业用途转载。是一个小版本一个小版本的升级,每个版本出【原创不易,请尊重版权】本文版权归作者所有,未经授权不得转载。一个新东西,那也不至于一下子学这么多东西本文版权归作者所有,未经授权不得转载。本文作者:唐霜,转载请注明出处。呀,在哪个语言里面,三个点(…【本文受版权保护】【原创不易,请尊重版权】;)也能算运算符?
【转载请注明来源】原创内容,盗版必究。本文作者:唐霜,转载请注明出处。for…of
为了方便,还是先说一下for…本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。;of吧,它是ES6新的遍历方式(《javascript的几种常见遍历数据结【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】构的语法》),目前来看,浏览器不支持,连babe【原创不易,请尊重版权】【本文受版权保护】l也不支持,要安装babel的扩展才支持未经授权,禁止复制转载。本文作者:唐霜,转载请注明出处。。
本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】for(let value of [1,2,3]) {
console.log(value);}
就是这么简单,可以遍历过程中获取valu【本文首发于唐霜的博客】转载请注明出处:www.tangshuang.nete值。
【本文首发于唐霜的博客】【版权所有,侵权必究】原创内容,盗版必究。…(扩展运算符)
…是我看到ES6里面,使用最【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。灵活的运算符,与其叫“扩展运算符”还不如【作者:唐霜】原创内容,盗版必究。叫“展开运算符”来的更加形象,它的作用,【版权所有,侵权必究】著作权归作者所有,禁止商业用途转载。说白了,就是展开一个数组,得到一组独立的转载请注明出处:www.tangshuang.net【原创不易,请尊重版权】值(顺序和数组元素顺序相同)。
【版权所有】唐霜 www.tangshu【作者:唐霜】【版权所有】唐霜 www.tangshuang.netang.net未经授权,禁止复制转载。说实话,第一次使用还是有点难以理解的。
本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】转载请注明出处:www.tangshua【未经授权禁止转载】本文作者:唐霜,转载请注明出处。ng.netconsole.log(...[1,2,3]);
上面的代码等于:
著作权归作者所有,禁止商业用途转载。【转载请注明来源】【访问 www.tangshuang.n【版权所有】唐霜 www.tangshuang.net【本文受版权保护】et 获取更多精彩内容】著作权归作者所有,禁止商业用途转载。console.log(1,2,3);
这种操作有点难以理解,为什么通过R【版权所有,侵权必究】未经授权,禁止复制转载。30;之后,一个数组就变成三个用逗号分开【原创不易,请尊重版权】原创内容,盗版必究。的值呢?你要问我,我也不知道,它就是这种【转载请注明来源】【本文受版权保护】作用。
原创内容,盗版必究。
...[1,2,3]的结果不是字符串,也不是数组,没有数据类【关注微信公众号:wwwtangshuangnet】本文版权归作者所有,未经授权不得转载。型可以定义它,只能称之为“一组用逗号分开本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。的值”。这种神奇的操作,让合并数组变得异【未经授权禁止转载】本文版权归作者所有,未经授权不得转载。常简单:
var a = [...[1,2,3],...[4,5,6]]; // [1,2,3,4,5,6]
它经常被用在函数的传参上:
【访问 www.tangshuang.n原创内容,盗版必究。原创内容,盗版必究。et 获取更多精彩内容】【版权所有,侵权必究】【版权所有,侵权必究】【关注微信公众号:wwwtangshua【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】ngnet】function sum(...args) {
return Math.sum(args);}sum(1,2,34,23,23,5); // 任意个数的参数
不过它不能用在对象上,而只能用在类似数组未经授权,禁止复制转载。【转载请注明来源】的数据结构上(包括类似数组的对象)。
【版权所有,侵权必究】【版权所有】唐霜 www.tangshu【未经授权禁止转载】【作者:唐霜】ang.net箭头函数
活久见的还有箭头函数=>,它的用法几乎闻所未闻,这也可以表示一个【访问 www.tangshuang.net 获取更多精彩内容】【版权所有,侵权必究】函数吗?可以,在ES6里面,就是这样干的【本文受版权保护】原创内容,盗版必究。:
[1,2,3].map(v => v + 2);
这在以前要写成:
【作者:唐霜】著作权归作者所有,禁止商业用途转载。【本文受版权保护】[1,2,3].map(function(v){
return v + 2;});
显然不是方便了一点点,而且从视觉上,完全【转载请注明来源】【转载请注明来源】没有函数的影子,是非常完整且单一的一条执【关注微信公众号:wwwtangshuangnet】【转载请注明来源】行语句。所有的普通函数都可以这样改写了:
著作权归作者所有,禁止商业用途转载。【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】ang.netfunction(params) {}// 改写为(params) => {}
那么什么函数是普通的呢?
本文版权归作者所有,未经授权不得转载。【原创内容,转载请注明出处】【未经授权禁止转载】【访问 www.tangshuang.n著作权归作者所有,禁止商业用途转载。【版权所有,侵权必究】et 获取更多精彩内容】- 不能在函数体内使用this 【本文受版权保护】【原创不易,请尊重版权】【原创内容,转载请注明出处】
- 不允许作为构造函数,不能用new实例化 转载请注明出处:www.tangshua【未经授权禁止转载】转载请注明出处:www.tangshuang.netng.net原创内容,盗版必究。
- 内部不存在arguments对象 【未经授权禁止转载】【原创内容,转载请注明出处】【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu【访问 www.tangshuang.net 获取更多精彩内容】本文版权归作者所有,未经授权不得转载。ang.net
其实说白了,你只能把它当做函数用,然后让【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】函数的其他功能见鬼去。
【版权所有,侵权必究】【本文首发于唐霜的博客】【关注微信公众号:wwwtangshua【转载请注明来源】未经授权,禁止复制转载。ngnet】Promise
Promise在之前的Javascrip【版权所有,侵权必究】转载请注明出处:www.tangshuang.nett里面就已经实现了,比如jQuery引入了Deferred,但是这次ES6把Promise写进了标【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。准里。
著作权归作者所有,禁止商业用途转载。本文作者:唐霜,转载请注明出处。转载请注明出处:www.tangshua【未经授权禁止转载】【版权所有】唐霜 www.tangshuang.netng.net本文作者:唐霜,转载请注明出处。function ajax(url) {
return new Promise((resolve, reject) => {
var xhr = new XMLHttpRequest();
xhr.open("GET", url);
xhr.onreadystatechange = handler;
xhr.responseType = 'json';
xhr.setRequestHeader('Accept', 'application/json');
xhr.send();
function handler() {
if(this.readyState !== 4) return;
if(this.status === 200) resolve(this.response);
else reject(new Error(this.statusText));
}
});}ajax('http://xxx').then(data => {}).catch(error => {});
过多就不多说了,自己和jQuery的Pr【本文受版权保护】【关注微信公众号:wwwtangshuangnet】omise对照感受。
【版权所有】唐霜 www.tangshu【作者:唐霜】【转载请注明来源】ang.net【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。Class 类及其继承
Javascript也开始支持类声明了,原创内容,盗版必究。【版权所有,侵权必究】不再需要function来声明,而且cl【未经授权禁止转载】转载请注明出处:www.tangshuang.netass类型就是class类型,不是fun【关注微信公众号:wwwtangshuangnet】【版权所有】唐霜 www.tangshuang.netction类型,所以在console中,【本文受版权保护】原创内容,盗版必究。看到的是class的数据结构,它和fun【原创不易,请尊重版权】【版权所有】唐霜 www.tangshuang.netction实例化出来的类还有区别。
未经授权,禁止复制转载。【作者:唐霜】Class的基本语法
class Person {
constructor(name,age) {
this.name = name;
this.age = age;
}
say(msg) {
alert(msg)
}}var mico = new Person('Mico',10);mico.say(`Hello, my name is ${mico.name}, and ${mico.age} years old.`);
而且Javascript的类也支持静态方【转载请注明来源】【关注微信公众号:wwwtangshuangnet】法:
【关注微信公众号:wwwtangshua【访问 www.tangshuang.net 获取更多精彩内容】【未经授权禁止转载】ngnet】【本文受版权保护】未经授权,禁止复制转载。class Person {
//...
static walk() { // 不要使用this
console.log('I am walking');
}}Person.walk();
当然,它一如既往的支持getter/se【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.nettter:
【作者:唐霜】未经授权,禁止复制转载。class Person {
get age() {
return this.age;
}
set age(x) {
this.age = x;
}}
可惜的是,Javascript的类还不支【作者:唐霜】著作权归作者所有,禁止商业用途转载。持像php一样的public, prot【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。ected, private类型的属性或【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】方法,其实我比较期待的是私有属性,因为我【原创不易,请尊重版权】本文作者:唐霜,转载请注明出处。们在类里面定义的所有属性,都不得不暴露给【原创不易,请尊重版权】原创内容,盗版必究。外部,虽然可以使用修饰符@(修饰符用的少转载请注明出处:www.tangshuang.net【本文受版权保护】,不在本文介绍范围内)实现隐藏,但是还是未经授权,禁止复制转载。【访问 www.tangshuang.net 获取更多精彩内容】很麻烦。我希望得到的效果如下:
【版权所有,侵权必究】【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。【本文受版权保护】// 注意,下面这种写法会报错,我只是用来阐述自己的想法class Person {
var name; // public
var age;
var sex;
let mother; // private
let father;
let telphone;
// ...}var sony = new Person('Sony',12);console.log(sony.name); // Sonyconsole.log(sony.father); // undefined
在类的作用域范围内,使用var或let进著作权归作者所有,禁止商业用途转载。著作权归作者所有,禁止商业用途转载。行声明,这显得很尴尬,因为在php里面用本文版权归作者所有,未经授权不得转载。转载请注明出处:www.tangshuang.netvar声明表示public,而如果用le【未经授权禁止转载】转载请注明出处:www.tangshuang.nett声明,表示仅在class这个{}花括号【版权所有,侵权必究】【关注微信公众号:wwwtangshuangnet】的块级作用域有效,所以很自然的:
原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。- 使用var声明表示外部可见,可以在外部进【转载请注明来源】未经授权,禁止复制转载。行修改 原创内容,盗版必究。本文版权归作者所有,未经授权不得转载。
- 而使用let声明,对外部不可见,但内部可本文作者:唐霜,转载请注明出处。原创内容,盗版必究。以用this.father获取和修改 未经授权,禁止复制转载。著作权归作者所有,禁止商业用途转载。
这只是我的一种想法,人微言轻,根本不可能【版权所有】唐霜 www.tangshuang.net【访问 www.tangshuang.net 获取更多精彩内容】被别人接受。都是前端,差距咋就那么大??
【原创内容,转载请注明出处】本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua本文作者:唐霜,转载请注明出处。【版权所有】唐霜 www.tangshuang.netngnet】目前解决这种私有属性的方法主要是通过Sy本文作者:唐霜,转载请注明出处。本文版权归作者所有,未经授权不得转载。mbol(Symbol也是ES6新增的特【本文首发于唐霜的博客】本文版权归作者所有,未经授权不得转载。性),具体请参考这里和这里。
【版权所有,侵权必究】【关注微信公众号:wwwtangshua【转载请注明来源】【关注微信公众号:wwwtangshuangnet】ngnet】【未经授权禁止转载】
继承
ES6里面,类的继承变得超级简单,几乎和原创内容,盗版必究。【转载请注明来源】php语法一摸一样:
【版权所有,侵权必究】未经授权,禁止复制转载。【访问 www.tangshuang.n【原创内容,转载请注明出处】著作权归作者所有,禁止商业用途转载。et 获取更多精彩内容】【本文首发于唐霜的博客】class Man extends Person {}var ken = new Man('Ken',22);
Mixin,继承于多个类
在Javascript里面比在Java里原创内容,盗版必究。【本文首发于唐霜的博客】面方便的多,Java里面只允许继承于一个【访问 www.tangshuang.net 获取更多精彩内容】【版权所有】唐霜 www.tangshuang.net父类,当然,在Javascript里面,【版权所有,侵权必究】【原创内容,转载请注明出处】默认是只能继承一个类,但是由于Javas【版权所有,侵权必究】【作者:唐霜】cript里面property的便捷性,未经授权,禁止复制转载。【原创不易,请尊重版权】继承于多个类其实只需要套路一下就可以了:本文作者:唐霜,转载请注明出处。原创内容,盗版必究。先通过某种方法构造,从多个类里面挑出需要【本文首发于唐霜的博客】【关注微信公众号:wwwtangshuangnet】的方法,把这些方法集中到某一个临时类身上本文版权归作者所有,未经授权不得转载。【版权所有】唐霜 www.tangshuang.net,再让你需要的类去继承这个临时类。
【版权所有】唐霜 www.tangshu未经授权,禁止复制转载。【转载请注明来源】ang.net【原创不易,请尊重版权】总结
上面这些提到的点,是我自己觉得牛逼闪闪的【本文受版权保护】【本文受版权保护】地方,是我经常用到的,当然,还有Gene【访问 www.tangshuang.net 获取更多精彩内容】转载请注明出处:www.tangshuang.netrator,Symbol,async,s本文作者:唐霜,转载请注明出处。本文作者:唐霜,转载请注明出处。et/map等都非常重要,是ES6里面的【版权所有】唐霜 www.tangshuang.net【版权所有,侵权必究】更牛逼闪闪的地方,但是因为使用到的频率于【版权所有,侵权必究】转载请注明出处:www.tangshuang.net我而言,主要是这些,所以我把它们拎出来。
本文作者:唐霜,转载请注明出处。【本文受版权保护】总体感觉上,ES6对Javascript著作权归作者所有,禁止商业用途转载。【未经授权禁止转载】的升级,是为了适应新的编程环境而来的大动【版权所有】唐霜 www.tangshuang.net【本文受版权保护】作,主要包括:
转载请注明出处:www.tangshua【作者:唐霜】【未经授权禁止转载】ng.net【转载请注明来源】未经授权,禁止复制转载。【转载请注明来源】- node的大行其道 本文版权归作者所有,未经授权不得转载。【访问 www.tangshuang.n【版权所有,侵权必究】【版权所有,侵权必究】et 获取更多精彩内容】【本文受版权保护】【本文首发于唐霜的博客】
- 以Javascript作为开发语言的大型【未经授权禁止转载】转载请注明出处:www.tangshuang.net项目的爆发 本文版权归作者所有,未经授权不得转载。本文版权归作者所有,未经授权不得转载。【版权所有,侵权必究】【版权所有】唐霜 www.tangshu本文作者:唐霜,转载请注明出处。【原创内容,转载请注明出处】ang.net
- 浏览器的混乱(谷歌这家霸道的公司) 【版权所有】唐霜 www.tangshu转载请注明出处:www.tangshuang.net【作者:唐霜】ang.net本文版权归作者所有,未经授权不得转载。【关注微信公众号:wwwtangshua著作权归作者所有,禁止商业用途转载。原创内容,盗版必究。ngnet】未经授权,禁止复制转载。
而且还有一点感受就是,各个语言之间的语法【本文受版权保护】著作权归作者所有,禁止商业用途转载。糖趋于统一,比如数组:
【原创内容,转载请注明出处】【版权所有】唐霜 www.tangshu【转载请注明来源】原创内容,盗版必究。ang.net【本文首发于唐霜的博客】// php$a = [];// javascriptvar a = [];
在php5.3之前,并不支持这种写法,就【原创内容,转载请注明出处】本文作者:唐霜,转载请注明出处。像Javascript在ES6之前不支持【原创不易,请尊重版权】【转载请注明来源】类的写法一样。语言之间的语法糖趋于统一,本文版权归作者所有,未经授权不得转载。【本文首发于唐霜的博客】从某种角度讲是编程世界里面一种默认甚至公未经授权,禁止复制转载。【关注微信公众号:wwwtangshuangnet】认的原则。我想,如果让每一门语言的创始人【版权所有】唐霜 www.tangshuang.net【未经授权禁止转载】重新开发这门语言,他们写出的语法糖可能会转载请注明出处:www.tangshuang.net本文版权归作者所有,未经授权不得转载。非常接近,甚至连语法也会接近,只不过由于【版权所有】唐霜 www.tangshuang.net本文版权归作者所有,未经授权不得转载。历史的原因,你不可能让php里面的对象采著作权归作者所有,禁止商业用途转载。【原创内容,转载请注明出处】用.点操作符来调用方法,也不可能让Jav【关注微信公众号:wwwtangshuangnet】转载请注明出处:www.tangshuang.netascript中的遍历临时变量前加一个&【原创内容,转载请注明出处】【关注微信公众号:wwwtangshuangnet】amp;来表示地址引用。
【本文受版权保护】【原创不易,请尊重版权】【本文首发于唐霜的博客】但是,如果世界上只有一门语言,这个世界将【版权所有】唐霜 www.tangshuang.net未经授权,禁止复制转载。黯淡无光。
本文作者:唐霜,转载请注明出处。【作者:唐霜】未经授权,禁止复制转载。

