ES6的一些知识学习
一、基础
ES6
- 类:
class A{
constructor(name,color){
this.name = name;
this.color = color;
} toString(){
console.log('name:'+this.name+'color:'+this.color);
}
} let dog = new A('dog','white');
dog.toString();
#一些变量判断方法
console.log(doga.hasOwnProperty('name'))
console.log(doga.__proto__.hasOwnProperty('toString')) - 继承 - 导入、导出
导出变量
export var name = 'xxxxxx' //test.js
var name = 'ssds';
var age = '';
export{name,age}; 导出函数
//myModule.js
export function myModule(args) { return args;
}
导入
import {myModule} from 'myModule'; //main.js
import {name,age} from 'xxx.js'; //test.js
//一条import语句可以同时导入默认函数和其他变量
import defaultMethod, {otherMethod} from 'xx.js'; -箭头(Arrow)函数 ()=>
v=>v+
(a,b)=>a+b
()=>{
alert("foo");
}
e=>{
if(e==){
return ;
}
return /e;
} - 函数参数默认值
function foo(height=,color='red'){
// .....
} - 模板字符串
不使用之前
var name = 'your name is' + first + ' ' +last + '.'
使用模板字符串
var name = `Your name is ${first} ${last}`
#${}完成字符串的拼接,变量放于大括号之中 -解构赋值
- 获取数组中的值
#从数组中获取值并赋值到变量中,变量的顺序域数组中的对象顺序对应
var foo = ['one','two','three','four'];
var [one,two,three] = foo;
console.log(two); //'two' //如果你想忽略某些值,可以如下
var [first, , ,last] = foo;
console.log(last); // 'four' //也可以先申明变量
var a,b;
[a,b] = [,];
console.log(a); // 1 //如果没有从数组中获取到值,也可以为变量设置一个默认值
var a,b
[a=,b=] = [];
console.log(a); //
console.log(b); //7 //通过解构赋值可以方便的交换两个变量的值
var a=;
var b=; [a,b] = [b,a];
console.log(a); //
console.log(b); //
- 获取对象中的值
const student ={
name : 'Ming',
age :'',
city : 'shanghai',
}; const{name,age,city} = student;
console.log(name); //'Ming'
console.log(age); //'18'
console.log(city); //'shanghai' - 延展操作符(Spread operator) - 函数调用
myFunction(...iterableObj);
- 数组构造或字符串
[...iterableObj,'',...'hello',];
- 构造对象时,进行克隆或者属性拷贝
let objClone ={...obj}; Example
在函数调用时使用
function sum(x,y,z){
return x+y+z;
}
const numbers = [,,];
//不使用延展操作
console.log(sum.apply(null,numbers));
//使用
console.log(sum(...numbers)); //
构造数组
const students = ['a','b'];
const persons = ['c',...students,'d','e'];
console.log(persons) //['a','b','c','d','e']
数组拷贝
var arr = [,,]
var arr2 = [...arr] //等同于arr.slice()
arr2.push();
console.log(arr2) //[1,2,3,4] - 展开语法和object.assign()行为一致,执行的都是浅拷贝(只遍历一层)
- 连接多个数组
var arr1 = [,,];
var arr2 = [,,];
var arr3 = [...arr1,...arr2]; //等同于 var arr4 = arr1.concat(arr2); #es2018中增加了对象的支持
var obj1 = {foo:'ac',x:};
var obj2 = {foo:'ad',y:}; var cloneobj = {...obj1}; // {foo:'ac',x:42}
var mergeobj = {...obj1,...obj2}; // {{foo:'ad',x:42,y:43}} 在React nativex中:
- 使用
<CustomComponent name='Jane' age={} />
等同于使用了...之后的,如下
const params ={
name:'Jine',
age:
}
<CustomComponent {...params} /> - 配合解构赋值避免传入一些不需要的参数
var params ={
name:'',
title:'',
type:'aaa'
}
#不想传type,其他需要的放other里
var {type,...other} =params;
<CustomComponent type='normal' number={}{...other} />
等同于
<CustomComponent type='normal' number={} name='' title='' /> - 对象属性简写
- 在es6中允许设置一个对象的属性的时候不指定属性名
- 不使用es6
const name='xx',age='',city='shang';
const student={
name:name,
age:age,
city:city
};
console.log(student); //{name:'xx',age:'12',city:'shang'}
- 使用es6
const name='xx',age='',city='shang';
const student ={
name,
age,
city
}
console.log(student); //{name:'xx',age:'12',city:'shang'} - Promise 异步编程的一种方案,必传统的callback更优雅,统一了用法,原生提供了Promise对象
- 不使用es6
嵌套两个setTimeout函数
setTimeout(function(){
console.log('hello'); //1s后输出‘hello’
setTimeout(function(){
console.log('hi'); //2s后输出‘hi’
},)
},);
- 使用es6
var waitSecond = new Pormise(function(resolve,reject)
{
setTimeout(resolve,);
}); waitSecond
.then(function(){
console.log("hello"); //1s后输出“hello”
return waitSecond;
})
.then(function(){
console.log("hi"); //2s后输出“hi”
return waitSecond;
});
上面的代码使用两个then来进行异步编程串行化,避免了回调地狱
------from muke
ES6的一些知识学习的更多相关文章
- Vue学习笔记-Vue.js-2.X 学习(一)===>基本知识学习
一 使用环境: windows 7 64位操作系统 二 IDE:VSCode/PyCharm 三 Vue.js官网: https://cn.vuejs.org/ 四 下载安装引用 方式1:直接 ...
- 网络知识学习2---(IP地址、子网掩码)(学习还不深入,待完善)
紧接着:网络知识学习1 1.IP地址 IP包头的结构如图 A.B.C网络类别的IP地址范围(图表) A.B.C不同的分配网络数和主机的方式(A是前8个IP地址代表网络,后24个代表主机:B是16 ...
- HTML5标签汇总及知识学习线路总结
HTML5标签汇总,以及知识学习线路总结.
- 安全测试3_Web后端知识学习
其实中间还应该学习下web服务和数据库的基础,对于web服务大家可以回家玩下tomcat或者wamp等东西,数据库的话大家掌握基本的增删该查就好了,另外最好掌握下数据库的内置函数,如:concat() ...
- GCC基础知识学习
GCC基础知识学习 一.GCC编译选项解析 常用编译选项 命令格式:gcc [选项] [文件名] -E:仅执行编译预处理: -S:将C代码转换为汇编代码: -c:仅执行编译操作,不进行连接操作: -o ...
- 毕业设计预习:VHDL入门知识学习(一) VHDL程序基本结构
VHDL入门知识学习(一) VHDL程序基本结构 简介 VHDL程序基本结构 简介 概念: HDL-Hardware Description Language-硬件描述语言-描述硬件电路的功能.信号连 ...
- 「日常训练&知识学习」单调栈
这几天的知识学习比较多,因为时间不够了.加油吧,为了梦想. 这里写几条简单的单调栈作为题解记录,因为单调栈的用法很简单,可是想到并转化成用这个需要一些题目的积淀. 相关博客参见:https://blo ...
- (转)Linux基础知识学习
Linux基础知识学习 原文:http://blog.csdn.net/ye_wei_yang/article/details/52777499 一.Linux的磁盘分区及目录 Linux的配置是通过 ...
- JavaScript ES6 数组新方法 学习随笔
JavaScript ES6 数组新方法 学习随笔 新建数组 var arr = [1, 2, 2, 3, 4] includes 方法 includes 查找数组有无该参数 有返回true var ...
随机推荐
- Excel关联xml文件
1.新建没传值的xml文件,变量名称自己定义好 2.打开excel,如果之前没有设置过,点击选项 如果当前Excel菜单栏中没有开发工具项,在自定义功能区先勾选上开发选项 3.点右下角的xml映射 弹 ...
- 如何更有效地说服开发接收你的bug?!
来来来,测试小伙伴们,看看以下这张图是不是觉得很熟悉.. 虽然这张图带点戏谑的成分,但确实折射出大部分IT公司测试人员在报bug时,与开发的沟通存在些许问题.如何更有效地说服开发接收你的bug,以下整 ...
- Android中软键盘展示、EditText焦点获取及windowSoftInputMode属性探究
2017-08-14 21:44:23 有很多中情况,分别展示. 1.Activity不做任何设置,布局使用LinearLayout 会自动滚动EditText之上的所有View,代码: <?x ...
- Android Stdio 无法打开模拟器
安装好了各种版本的AVD,有个版本4.1,API版本16,219MB的模拟器是可以打开的,但是基本不能用,只能看到首界面,跳转什么的完全不行. 除此之外其它高版本的模拟器都不能用(API版本>2 ...
- spring的bean创建过程
Spring的bean创建过程 步骤 执行过程 描述 1 ThreadLocal.set bean创建之前将beanName的一些属性放进ThreadLocal,避免多线程创建bean导致问题,并发创 ...
- Python列表以及列表的处理方法
在Python中,当我们需要存储大量的数据时,可使用列表存储,列表本质是一种有序的集合 格式:列表名 = [列表元素1,列表元素2,列表元素3,...列表元素n] 如果想创建一个只有单个元素的列表,格 ...
- OO第二单元总结之线程大冒险第一关
第二个单元的三次作业均为多线程电梯的设计,旨在让我们能够理解多线程在面向对象设计时的重要意义,并熟练掌握在保证线程安全和性能高效情况下的多线程协同的设计模式——在本次作业中主要体现在生产者-消费者模式 ...
- 关于“load”方法
load是一个方法,在程序文件中,只有ruby遇到它的时候才会执行.Ruby不会搜索整个文件去执行load命令.也就是说,当Ruby解释器遇到它的时候,它才会去寻找它要加载的文件.这意味着需要加载的文 ...
- Oracle数据库各种名字的区别
数据库名(DB_NAME).数据库实例名(INSTANCE_NAME).操作系统环境变量(ORACLE_SID).数据库服务名(SERVICE_NAME).数据库域名(DB_DOMAIN)以及全局数据 ...
- idea构建spark开发环境,并本地运行wordcount
1.首先现在idea,官网:https://www.jetbrains.com/idea/ 2.安装jdk1.8,scala2.11 3.下载idea后,需要在idea中安装scala的插件,安装的方 ...