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

