{ //原始对象 let obj={ time:'2017-03-11', name:'net', _r:123 }; //(代理商)第一个参数代理对象,第二个参数真正代理的东西 let monitor=new Proxy(obj,{ // 拦截对象属性的读取 get(target,key){ return target[key].replace('2017','2018') }, // 拦截对象设置属性 set(target,key,value){ if(key==='name'){ //赋值…
let/const(常用) let,const用于声明变量,用来替代老语法的var关键字,与var不同的是,let/const会创建一个块级作用域(通俗讲就是一个花括号内是一个新的作用域) 这里外部的console.log(x)拿不到前面2个块级作用域声明的let: { let s =0; } { let s =2; } console.log(s) //Uncaught ReferenceError: s is not defined 在日常开发中多存在于使用if/for关键字结合let/co…
2019年12月24日16:22:24 2019年10月09日12:04:44 1. ES6介绍 1.1 新的 Javascript 语法标准 --2015年6月正式发布 --使用babel语法转换器,支持低端浏览器 --流行的库基本都基于ES6构建,React默认使用ES6新语法开发 1.2 ES6包含内容 块级作用域.字符串.函数 对象扩展.解构 类.模块化等 2. 作用域 2.1 let let 声明的变量只在 let 命令所在的代码块内有效. 定义变量使用let替代var { let a…
什么是ECMAScript? ECMAScript是浏览器脚本语言的规范,而我们熟知的js语言,如JavaScript则是规范的具体实现.es6就好比Java的jdk. 一.es6语法详解:let声明变量 1.var声明的变量往往会越域:let声明的变量有严格局部作用域 { var a = 1; let b = 2; } console.log(a) // 1 console.log(b) // Uncaught ReferenceError: b is not defined 2.var 可以…
目录 * 核心例子 * 修改成静态变量(const)或块级变量(let) * 开始修改 * 疑问解释(重复定义会发生什么) * 疑问解释(let的块级作用域是怎样的) * 疑问解释(const定义的变量在基础数据类型和引用类型中的差异) * 修改成Promise的形式 * 预备知识(回调函数是什么) * 预备知识(如何把回调函数改为Promise) * 开始修改 * 修改成箭头函数(Arrow Function) * 预备知识(箭头函数是什么) * 预备知识(箭头函数函数中的this是个坑) *…
{ let arr = Array.of(3, 4, 7, 9, 11); console.log('arr', arr); //[3,4,7,9,11] let empty = Array.of(); console.log(empty); //[] } //ES6为Array增加了from函数用来将其他对象转换成数组. //当然,其他对象也是有要求,也不是所有的,可以将两种对象转换成数组. //1.部署了Iterator接口的对象,比如:Set,Map,Array. //2.类数组对象,什么…
Node本身已经支持部分ES6语法,但是import export,以及async await(Node 8 已经支持)等一些语法,我们还是无法使用.为了能使用这些新特性,我们就需要使用babel把ES6转成ES5语法 安装babel npm install babel-cli -g <!-- more --> 基础知识 babel的配置文件是.babelrc { "presets": [] } 新建一个demo文件夹,文件夹下新建 1.js const arr = [1,…
如果你在 template 中,使用了 es6 及以上的语法,那么,在部分ios.安卓.微信浏览器中,打开页面后显示一片空白内容.如下: <ul id="example-1"> <li v-for="item in items.map(item => item.message)"> {{ item}} </li> </ul> 将 ES6 语法改为 ES5,即可解决. <ul id="example…
ES6中map和set用法 --转载自廖雪峰的官方网站 一.map Map是一组键值对的结构,具有极快的查找速度. 举个例子,假设要根据同学的名字查找对应的成绩,如果用Array实现,需要两个Array: var names = ['Michael', 'Bob', 'Tracy']; var scores = [95, 75, 85]; 给定一个名字,要查找对应的成绩,就先要在names中找到对应的位置,再从scores取出对应的成绩,Array越长,耗时越长. 或者通过object键值对的方…
index.js const arr = [ new Promise(()=>{}), new Promise(()=>{}) ]; arr.map(item => { console.log(item); }) index.html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="v…