ES6: ECMA 第六次改版
块级作用域:
凡是被{ }包裹住的代码都是块级作用域,除了对象
特点:会造成一个暂时性死区
新增声明变量的两种方式:
let:
a. 不能重复被定义
b.没有变量声明提升
c.有块级作用域的用法,可以在块级作用域里做个保留
const:
a.定义一个常量,不允许被修改
b.没有变量声明提升
c.声明了不能不允许不赋值
d.支持块级作用域
字符串模板:
ES6之前
var age = 20;
var str = "<div class = 'box'><span>"+age+"</span></div>"
ES6之后
var age = 20;
var str = `<div class = 'box'><span>${age}</span></div>`
var age = "20";
var str = `<div class = 'box'><span>${age.slice(1)}</span></div>` // 变量可以做很多js操作
字符串新增api:
includes:
匹配当前字符是否出现在字符串中,如果存在则返回true,不存在则返回false
var str = "1906"
console.log(str.includes(5)) //false
console.log(str.includes(1)) //true
startsWith:
匹配字符串的第一个字符 如果存在则返回true 不存在返回false
var str="1906"
console.log(str.startsWith(9)) //false
endsWith:
匹配字符串的最后一个字符 如果存在则返回true 不存在返回false
var str="1906"
console.log(str.endsWith(9)) //false
repeat(n) 重复多少次
var str="1906"
console.log(str.repeat(4) //代表当前这个句话重复4次
解构赋值:
按照某种规则,将数据进行拆分
let arr = [10,20,30]
let [a,b] = arr
console.log(a,b) //10 20
let [,c,d] = arr
console.log(c,d) //20 30
let obj = {a:1,b:2}
let {a,b} = obj
console.log(a,b) //1 2
var obj = {a:10,b:20,info:{name:"张三"}}
var {info:{name:_name}} = obj;
console.log(_name) //张三
扩展运算符:
var arr = [10,20,30,40]
fn(...arr) //将数组的值展开传入fn中
var obj = {width:"100px",height:"200px"}
var obj = {background:"red",lineHeight:"30px"}
var newObj = {...obj,...obj1}
console.log(newObj) // {width:"100px",height:"200px",background:"red",lineHeight:"30px"}将两个对象值展开合并到一个对象里
Symbol:独一无二
作用:保护对象的属性和值
数据保护
Symbol是一个函数,
也是ES6新增的数据类型,基本数据类型变成6个
for in 是遍历不出来对象中Symbol的属性
一般情况下用来做对象的key值
const a = Symbol();
console.log(typeof a) //Symbol
const a = Symbol("a");
const b = Symbol("a");
console.log(a == b) //false
var obj = {}
var mySymbol = Symbol()
obj[mySymbol] =18
obj[Symbol()] =19
obj[Symbol()] =20
obj.a = 10
obj.b = 23
console.log(obj) //{Symbol():18,Symbol():19,Symbol():20,a:10,b:23}
//object.keys( ),这个方法可以获取对象身上所有的key值,不包括Symbol,返回值是一个数组
let arr = Object.keys(obj);
console.log(arr); //["a","b"]
//获取Symbol的key值
var arr1 = Object.getOwnPropertySymbols(obj);
console.log(arr1) //[Symbol(),Symbol(),Symbol()]
console.log(obj[arr1[0]]) //18
对象新增方法
对象的简写:
let a = 10;
let obj = {
//a=a;
a, //key与value值相同的情况下 ,可以写一个值
// show:function(){}
show(){} //方法简写
}
Object.is( ) 用来判断两个对象的索引是否指向同一索引地址
let obj = {a:10,b:20}
let obj1 = obj
let obj2 = {a:10,b:20}
console.log(Object.is(obj,obj1)) //true
console.log(Object.is(obj,obj2)) //false
Object.assign( ) 合并对象
参数1:需要合并的对象
参数2:被合并的对象
参数3:被合并的对象
......
返回值是一个新的对象
var obj = {a:10,b:13}
var obj1 = {c:131,d:23}
var newObject = Object.assign(obj,obj1)
console.log(newObj) //{a:10,b:13,c:131,d:23}
数组新增方法:
Array.of:将一组数值转换成数组
返回值是一个数组
let arr = Array.of(1,2,3,4)
console.log(arr) //[1,2,3,4]
includes:查找当前值是否属于当前数组 成功true 失败false
var arr = [12,13,14,111]
console.log(arr.includes(11)) //false
Array.from:将一个伪数组转换成纯数组
function fn(){
console.log(Array.from(arguments))
}
fn(1,2,3,4,5) //[1,2,3,4,5]
console.log(Array.from(arguments) instanceof Array) //true
Array.fill( )填充
参数1:需要填充的数据
参数2:(包括)填充开始的下标
参数3:(不包括)结束的下标
var arr = [10,20,30,40]
console.log(arr.fill("a",1,3)) //[10,"a","a",40]
Array.find( ) 根据条件找到相对应的值(最近的一个值)
var arr = [10,20,30,40]
var n = arr.find(function(item,index,array)){
return item>20
}
console.log(n) //30
Array.findIndex( ) 根据条件找到相对应值的下标(最近的一个值)
var arr = [10,20,30,40]
var n = arr.findIndex(function(item,index,array)){
return item>20
}
console.log(n) //2
函数参数的扩展
ES6之前
function fn(a){
var a = a || 10; //用户传递参数就用参数,没传参数就是10
console.log(a);
}
fn();
ES6之后
function fn1(a=10){
console.log(a);
}
fn1(); // 10
fn1("aaa"); //"aaa"
箭头函数:
简单的来说就是把function 换成了 =>
var fn = ()=>{
console.log("111")
}
fn();
语法1:
var fn = a=>a;
console.log(fn(2))
var fn = (a,b)=>a+b;
不写{}代表的是return
语法2:
var fn = ()=>({})
console.log(fn())
特点:
1、箭头函数中没有this的指向,在箭头函数中this的指向会指向离他最近的那个作用域
2、箭头函数中没有arguments这个参数
3、不能当做构造函数
4、箭头函数不能当做generator函数
- es6新增特性总结
定义 ES6是ECMA为JavaScript制定的第6个标准版本,标准委员会决定,标准在每年6月正式发布并作为当年的正式版本,接下来的时间里就在此版本的基础上进行改动,直到下一年6月草案就自然变成新一 ...
- 10.1 ES6 的新增特性以及简单语法
ES6 的新增特性以及简单语法 let 和 const 模板字符串 箭头函数 对象单体模式 es6面向对象 模块化 let 和 const 之前一直用 var 来声明变量,ES6 新增 let 和 ...
- ES6(函数新增特性)
ES6(函数新增特性) 1.函数参数默认值 没有 y 时,默认就是world 有 y 时,输出值即可 (错误) (C有默认值,正确) 默认值后面不能再有没有默认值的变量 2.作用域 y 取其前面的 x ...
- ES6新增常见特性
一:声明属性let const var let const 区别 1.var声明变量会发生变量提升,let.const不会发生变量提升 2.var允许重复声明变量,let不可以 3.const声明变量 ...
- ES6 新特性
ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准.因为当前版本的ES6是在2015年发布的,所以又称ECMAScript 2015. 也就是说,ES6就是ES2015. ...
- ES6新特性概览
本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代号harmony( ...
- ES6 — 新增关键字let、const
ECMAScript 是什么? 首先,我们都知道JavaScript由三部分组成:ECMAScript,DOM,BOM: 其中的ECMAScript是Javascript的语法规范. ECMAScri ...
- 你不知道的JavaScript--Item24 ES6新特性概览
ES6新特性概览 本文基于lukehoban/es6features ,同时参考了大量博客资料,具体见文末引用. ES6(ECMAScript 6)是即将到来的新版本JavaScript语言的标准,代 ...
- 前端入门21-JavaScript的ES6新特性
声明 本篇内容全部摘自阮一峰的:ECMAScript 6 入门 阮一峰的这本书,我个人觉得写得挺好的,不管是描述方面,还是例子,都讲得挺通俗易懂,每个新特性基本都还会跟 ES5 旧标准做比较,说明为什 ...
随机推荐
- PAT Advanced 1065 A+B and C (64bit) (20 分)(关于g++和clang++修改后能使用)
Given three integers A, B and C in [−], you are supposed to tell whether A+B>C. Input Specificati ...
- CentOS8 安装部署Apache+Php+MariaDB(pdo扩展)
使用新的CentOS8系统架设PHP服务器,因现在主流数据库mysql已闭源了,所以现在改为使用MariaDB.而php7以后不支持mysqli链接,只有pdo方式,为了安装pdo扩展,所以重新编译安 ...
- 【bzoj 4554】【Tjoi2016&Heoi2016】【NOIP2016模拟7.12】游戏
题目 分析 当没有石头的时候,就用二分图匹配来做. 但现在加入了石头, 所以,求出每行和每列联通快的个数,如果有一块平地,包括在某个行联通块以及某个列联通块中,连边. //无聊打了网络流,匈牙利也可以 ...
- java 生成透明背景图片
//开始绘图 graphics2d.setBackground(Color.WHITE); graphics2d.clearRect(0, 0, width, height); graphics2d. ...
- win10 64 位安装 MySQL(mysql-5.7.17-winx64)
版权声明:本文为搜集借鉴各类文章的原创文章,转载请注明出处:http://www.cnblogs.com/2186009311CFF/p/6517470.html. win10 64 位安装 MySQ ...
- php end()函数 语法
php end()函数 语法 作用:将数组内部指针指向最后一个元素,并返回该元素的值(如果成功).博智达 语法:end(array) 参数: 参数 描述 array 必需.规定要使用的数组. 说明:如 ...
- 【CF1249D】Too Many Segments(贪心,set,vector)
题意:给定n条线段和覆盖上限k,每条线段都覆盖了区间内的整点 问最少删掉几条线段能使所有的整点都被覆盖不超过k次 k<=n<=2e5,l[i],r[i]<=2e5 思路:比赛时候不会 ...
- 2014ACM-ICPC广州站题解(摘自闭幕式)
第39届ACM-ICPC亚洲区广州站题解 Ltysky摘抄自闭幕式题目分析 Problem A 满足px+qy=c的点(x,y)在一条直线上,而c的值由直线的截距确定,所以最大化c,就要在糖果(x,y ...
- [POJ1637]Sightseeing tour:混合图欧拉回路
分析 混合图欧拉回路问题. 一个有向图有欧拉回路当且仅当图连通并且对于每个点,入度\(=\)出度. 入度和出度相等可以联想到(我也不知道是怎么联想到的)网络流除了源汇点均满足入流\(=\)出流.于是可 ...
- Oracle10g 64位 在Windows 2008 Server R2 中的安装 DBconsole无法启动
致谢!本文参考http://www.cnblogs.com/leiOOlei/archive/2013/08/19/3268239.html 背景: 操作系统Windows 2008 Server R ...