es6(1)
1.var let const
var---变量,重复定义不报错,没有块级作用域,不能限制修改
if(12>5){
var a=12;
}
alert(a); //弹出12 let---变量,重复定义报错,有块级作用域,可以限制修改 if(12>5){
let a=12;
}
alert(a); //报错,let有块级作用域的概念,只在if代码段内有效 <!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title></title>
<script>
window.onload=function(){
var aBtn=document.getElementsByTagName('input'); for(let i=0;i<aBtn.length;i++){
aBtn[i].onclick=function(){
alert(i);
}
}
}
</script>
</head>
<body>
<input type="button" name="" value="a">
<input type="button" name="" value="b">
<input type="button" name="" value="c">
</body>
</html>
三个按钮分别输出0,1,2 const---常量,重复定义报错,有块级作用域,可以限制修改 const a=12;
a=5;
alert(a); //报错,const是常量,不能修改
2.箭头函数
只有一个参数,()可以省
只有一个语句,还是return,{}可以省 一、把function去掉,加上=>
function (a,b,c){
//代码
} (a,b,c)=>{
//代码
}
二、示例
function show(fn){
fn(12,5);
} show((a,b)=>{
alert(a*b);
})
三、只有一个参数,()可以省
let show=a=>{
alert(a)
}
show(5);
四、只有一个语句,还是return,{}可以省
let sum=(a,b)=>a+b;
alert(sum(1,2));
五、实现排序
let arr=[2,5,4,1,9,6];
arr.sort((a,b)=>a-b);
alert(arr);
3.参数扩展(...arg)
function show(a,b,...arg){
alert(arg);
} show(1,2,3,4,5,6); ///3,4,5,6 注意:...arg只能放在参数的最后一个
function show(a,b,...arg,c){
alert(arg);
} show(1,2,3,4,5,6); //报错,...arg没有放在参数的最后一个
4.展开数组
一、采用...arg,数组展开为1,2,3
let arr=[1,2,3];
function sum(a,b,c){
alert(a+b+c);
} sum(...arr); //6
二、展开数组,并连接数组
let arr1=[1,2,3];
let arr2=[4,5,6]; let arr=[...arr1,...arr2];
alert(arr); //1,2,3,4,5,6
5.数组map方法(映射)
let arr=[1,2,3,4];
let result=arr.map(item=>item*2);
alert(result); //2,4,6,8
6.数组filter方法(过滤)
let arr=[1,2,3,4,5,6,7,8];
let result=arr.filter(item=>item%2);
alert(result); //1,3,5,7
7.数组forEach方法(遍历)
let arr=[1,2,3,4,5,6,7,8];
let result=arr.forEach((item,index)=>{
alert(`第${index+1}是${item}`)
})
8.数组reduce方法(汇总)
//求平均数
let arr=[1,2,3,4,5,6];
let result=arr.reduce((tamp,item,index)=>{
if(index<arr.length-1){
return tamp+item;
}else{
return (tamp+item)/arr.length;
}
})
alert(result);
9.字符串模板(``)
//可以换行
let str=`ab
c`;
alert(str);
10.面向对象(class、super、extends)
class User{
constructor(name,pass){
this.name=name;
this.pass=pass;
} login(){
alert('登录成功')
}
} class VIPUser extends User{
constructor(name,pass,level){
super(name,pass);
this.level=level;
} download(){
alert('下载成功')
}
} let p=new VIPUser('blue',123,8);
p.login();
p.download();
alert(p.name);
alert(p.pass);
alert(p.level);
11.解构赋值
//数组,一一对应
let [a,b,c]=[1,2,3];
alert(a);
alert(b);
alert(c);
//对象,一一对应
let {a,b,c}={'a':'1','b':'2','c':'3'};
alert(a);
alert(b);
alert(c);
12.promise
一、
let p=new Promise(function(resolve,reject){
$.ajax({
url:'data/1.txt',
dataType:'json',
success(arr){
resolve(arr)
},
error(err){
reject(err)
}
})
}) p.then(arr=>{
alert('成功了'+arr)
},err=>{
alert('失败了')
})
二、
let p1=new Promise(function(resolve,reject){
$.ajax({
url:'data/1.txt',
dataType:"json",
success(arr){
resolve(arr)
},
error(err){
reject(err)
}
})
}); let p2=new Promise(function(resolve,reject){
$.ajax({
url:'data/2.txt',
dataType:'json',
success(arr){
resolve(arr)
},
erros(err){
reject(err)
}
})
}); let p3=new Promise(function(resolve,reject){
$.ajax({
url:'data/3.txt',
dataType:'json',
success(arr){
resolve(arr)
},
error(err){
reject(err)
}
})
}); Promise.all([p1,p2,p3]).then(function(arr){
let [r1,r2,r3]=arr;
alert(r1);
alert(r2);
alert(r3);
},function(){
alert('失败了')
})
1.var let const var---变量,重复定义不报错,没有块级作用域,不能限制修改 if(12>5){ var a=12; } alert(a); //弹出12
let---变量,重复定义报错,有块级作用域,可以限制修改
if(12>5){ let a=12; } alert(a); //报错,let有块级作用域的概念,只在if代码段内有效
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> <script> window.onload=function(){ var aBtn=document.getElementsByTagName('input');
for(let i=0;i<aBtn.length;i++){ aBtn[i].onclick=function(){ alert(i); } } } </script> </head> <body> <input type="button" name="" value="a"> <input type="button" name="" value="b"> <input type="button" name="" value="c"> </body> </html> 三个按钮分别输出0,1,2
const---常量,重复定义报错,有块级作用域,可以限制修改
const a=12; a=5; alert(a); //报错,const是常量,不能修改 2.箭头函数 只有一个参数,()可以省 只有一个语句,还是return,{}可以省
一、把function去掉,加上=> function (a,b,c){ //代码 }
(a,b,c)=>{ //代码 } 二、示例 function show(fn){ fn(12,5); }
show((a,b)=>{ alert(a*b); }) 三、只有一个参数,()可以省 let show=a=>{ alert(a) } show(5); 四、只有一个语句,还是return,{}可以省 let sum=(a,b)=>a+b; alert(sum(1,2)); 五、实现排序 let arr=[2,5,4,1,9,6]; arr.sort((a,b)=>a-b); alert(arr); 3.参数扩展(...arg) function show(a,b,...arg){ alert(arg); }
show(1,2,3,4,5,6); ///3,4,5,6
注意:...arg只能放在参数的最后一个 function show(a,b,...arg,c){ alert(arg); }
show(1,2,3,4,5,6); //报错,...arg没有放在参数的最后一个 4.展开数组 一、采用...arg,数组展开为1,2,3 let arr=[1,2,3]; function sum(a,b,c){ alert(a+b+c); }
sum(...arr); //6 二、展开数组,并连接数组 let arr1=[1,2,3]; let arr2=[4,5,6];
let arr=[...arr1,...arr2]; alert(arr); //1,2,3,4,5,6 5.数组map方法(映射) let arr=[1,2,3,4]; let result=arr.map(item=>item*2); alert(result); //2,4,6,8 6.数组filter方法(过滤) let arr=[1,2,3,4,5,6,7,8]; let result=arr.filter(item=>item%2); alert(result); //1,3,5,7 7.数组forEach方法(遍历) let arr=[1,2,3,4,5,6,7,8]; let result=arr.forEach((item,index)=>{ alert(`第${index+1}是${item}`) }) 8.数组reduce方法(汇总) //求平均数 let arr=[1,2,3,4,5,6]; let result=arr.reduce((tamp,item,index)=>{ if(index<arr.length-1){ return tamp+item; }else{ return (tamp+item)/arr.length; } }) alert(result); 9.字符串模板(``) //可以换行 let str=`ab c`; alert(str); 10.面向对象(class、super、extends) class User{ constructor(name,pass){ this.name=name; this.pass=pass; }
login(){ alert('登录成功') } }
class VIPUser extends User{ constructor(name,pass,level){ super(name,pass); this.level=level; }
download(){ alert('下载成功') } }
let p=new VIPUser('blue',123,8); p.login(); p.download(); alert(p.name); alert(p.pass); alert(p.level); 11.解构赋值 //数组,一一对应 let [a,b,c]=[1,2,3]; alert(a); alert(b); alert(c); //对象,一一对应 let {a,b,c}={'a':'1','b':'2','c':'3'}; alert(a); alert(b); alert(c); 12.promise 一、 let p=new Promise(function(resolve,reject){ $.ajax({ url:'data/1.txt', dataType:'json', success(arr){ resolve(arr) }, error(err){ reject(err) } }) })
p.then(arr=>{ alert('成功了'+arr) },err=>{ alert('失败了') }) 二、 let p1=new Promise(function(resolve,reject){ $.ajax({ url:'data/1.txt', dataType:"json", success(arr){ resolve(arr) }, error(err){ reject(err) } }) });
let p2=new Promise(function(resolve,reject){ $.ajax({ url:'data/2.txt', dataType:'json', success(arr){ resolve(arr) }, erros(err){ reject(err) } }) });
let p3=new Promise(function(resolve,reject){ $.ajax({ url:'data/3.txt', dataType:'json', success(arr){ resolve(arr) }, error(err){ reject(err) } }) });
Promise.all([p1,p2,p3]).then(function(arr){ let [r1,r2,r3]=arr; alert(r1); alert(r2); alert(r3); },function(){ alert('失败了') })
es6(1)的更多相关文章
- ES6模块import细节
写在前面,目前浏览器对ES6的import支持还不是很好,需要用bable转译. ES6引入外部模块分两种情况: 1.导入外部的变量或函数等: import {firstName, lastName, ...
- webpack+react+redux+es6开发模式
一.预备知识 node, npm, react, redux, es6, webpack 二.学习资源 ECMAScript 6入门 React和Redux的连接react-redux Redux 入 ...
- ES6的一些常用特性
由于公司的前端业务全部基于ES6开发,于是给自己开个小灶补补ES6的一些常用特性.原来打算花两天学习ES6的,结果花了3天才勉强过了一遍阮老师的ES6标准入门(水好深,ES6没学好ES7又来了...) ...
- ES6(块级作用域)
我们都知道在javascript里是没有块级作用域的,而ES6添加了块级作用域,块级作用域能带来什么好处呢?为什么会添加这个功能呢?那就得了解ES5没有块级作用域时出现了哪些问题. ES5在没有块级作 ...
- es6小白学习笔记(一)
1.let和const命令 1.es6新增了let和const命令,与var用法类似,但它声明的变量只在let所在的代码块内有效(块级作用域,es5只有全局和函数作用域) { let a = 1; v ...
- ES6之变量常量字符串数值
ECMAScript 6 是 JavaScript 语言的最新一代标准,当前标准已于 2015 年 6 月正式发布,故又称 ECMAScript 2015. ES6对数据类型进行了一些扩展 在js中使 ...
- ES6之let命令详解
let与块级作用域 { var foo='foo'; let bar='bar'; } console.log(foo,'var'); //foo varconsole.log(bar ,'bar') ...
- ES6 箭头函数中的 this?你可能想多了(翻译)
箭头函数=>无疑是ES6中最受关注的一个新特性了,通过它可以简写 function 函数表达式,你也可以在各种提及箭头函数的地方看到这样的观点——“=> 就是一个新的 function”. ...
- ES6+ 现在就用系列(二):let 命令
系列目录 ES6+ 现在就用系列(一):为什么使用ES6+ ES6+ 现在就用系列(二):let 命令 ES6+ 现在就用系列(三):const 命令 ES6+ 现在就用系列(四):箭头函数 => ...
- ES6+ 现在就用系列(一):为什么使用ES6+
系列目录 ES6+ 现在就用系列(一):为什么使用ES6+ ES6+ 现在就用系列(二):let 命令 ES6+ 现在就用系列(三):const 命令 ES6+ 现在就用系列(四):箭头函数 => ...
随机推荐
- 采集douban
# -*- coding: utf-8 -*-"""Created on Thu Oct 31 16:14:02 2019 @author: DELL"&quo ...
- 通用权限系统-Spring-Boot-Starter
Spring-Boot-Starter 自定义Starter 案例一:读取application.yml中的参数 1.创建 1.创建maven工程hello-spring-boot-starter 2 ...
- allure报告生成
allure生成测试报告 1.生成xml文件 pytest 测试文件所在路径 --alluredir 生成的测试结果数据保存的目录 pytest --alluredir=resport/xml/ D ...
- html实现原生table并设置表格边框的两种方式
虽然第三方表格插件多不胜数,但是很多场景还是需要用到原生<table>,掌握html原生table的实现方法,是前端开发的必备技能.例如:print-js打印.html2canvas生成图 ...
- 打开页面就能玩?ZEGO 发布行业首套 Web 端在线 KTV 解决方案
近些年,在线K歌行业逐渐开始规模化发展,活跃用户不断破新高,据 ZEGO 即构科技研究院数据显示,2021 年中国在线 K 歌用户规模逾 5.2亿,网民渗透率达到 50%. 凭借着极大的便利性和娱乐性 ...
- CentOS 7相关操作
防火墙操作 开启防火墙 sudo systemctl start firewalld.service 查看防火墙状态 sudo systemctl status firewalld.service 关 ...
- 订单逆向履约系统的建模与 PaaS 化落地实践
导读 本文重点介绍了京东零售电商业务在订单逆向履约上面的最佳技术实践,京东零售快退平台承接了零售几乎所有售前逆向拦截和退款业务,并在长期的业务和技术探索中沉淀了丰富的业务场景设计方案.架构设计经验,既 ...
- WPF 中WebBrowser 控件的“允许阻止的内容”修复(引用本地的html页)
解决方法:(个人理解:导致原因就是iE安全机制的问题吧).在你的HTML里面第一行加: <!-- saved from url=(0014)about:internet -->具体原因可以 ...
- jsp中的一些问题
jsp里的${pageContext.request.contextPath} 在JSP中,${pageContext.request.contextPath}是一个EL表达式(Expression ...
- CF992E Nastya and King-Shamans 题解
传送门 分析 由于满足 \(a_i\ge0\),所以 \(s_i\) 单调不减. 当我们找到一个 \(i\) 时,不管 \(i\) 是否满足,下一个可能的一定大于等于 \(a_i+s_{i-1}\). ...