ES6的小知识(后半部分)
一、iterator和for-of循环
在js里有数组和对象,es6又新出现了set和map这样js就有了四种数据集合,这样可以组合使用他们,比如数组里拥有对象,set等,这样就需要一个统一的
接口机制来处理不同的数据结构,iterator就是这样的接口,它为不同的数据结构提供统一的访问机制,任何数据结构只要部署iterator接口就可以遍历操作
他们,并且iterator接口主要供for...of遍历
//iterator接口
const arr = [1,2];
function iterator(arr){
let index = 0;
return{
next:function(){
return index < arr.length ? {value:arr[index++],done:false}:
{value:undefined,done:true}
}
}
}
const it = iterator(arr);
console.log(it.next());//{value:1,done:false}
console.log(it.next());//{value:2,done:false}
console.log(it.next());//{value:undefined,done:true}
二、class类的使用
es6添加了class,使ECMAScript语法更偏向于后台语言
class Cher{
constructor(a,b){
this.a = a;
this.b = b;
return this;
}
chun(){
console.log(this.a +'===='+ this.b);
}
}
const cher = new Cher('111','222');
cher.chun(); //111====222
在这里面,constructor方法是构造方法,一个类里必须要有constructor,如果没有,它会默认添加一个空的constructor,this代表着实例对象,里面还有一个chun方法,前面是不需要加function关键字的,方法之间是不需要逗号隔开,否则会报错,创建实例对象的时候是和es5一样的,必须要加new,否则也是会报错的
三、内置对象的扩展
1、字符串的扩展
字符串添加了一个模板字符串(超级字符串),那就是反引号,并且换行的时候不在需要繁琐的加号连接,而且在字符串里有变量的时候也不需要加号连接,只需要使用
${}操作就可以了
//html代码
<p></p> //js代码
let str = 'o'; document.getElementsByTagName('p')[0].innerHTML = `hell${str},world!!!` //hello,world!!!
并且还添加了一些字符串的方法:
repeat:对字符串进行重复的操作
let str1 = '1';
let str2 = str1.repeat(5);
console.log(str2); //
includes()、startWith()、endWith()分别是查看是否含有某个字符串,字符串里的开始部分是否含有某个字符串,字符串的结尾部分是否含有某个字符串,他们返回的是一个布尔值
2、数组的扩展
Array.from():把类数组变成数组
类数组最常见的就是js选择一组元素标签
let aP = document.getElementsByTagName('p');
console.log(Array.isArray(aP)); //false
let ap = Array.from(aP);
console.log(Array.isArray(ap)); //true
Array.of():创造一个数组
const arr = Array.of(a);
console.log(arr) //[a]
fill():数组填充,第一个参数是填充的字符串,也可以有第二个参数是从什么位置开始填充(可以没有第二个参数)
const arr = ['a','b','c'];
arr.fill('abc');
console.log(arr) //['abc','abc','abc']
find()、findIndex() : 对数组进行赛选
const arr = [1,2,3,4,5];
let arr1 = arr.find(function(a){
return a > 3;
})
console.log(arr1); //4,5如果没有找到符合条件的值就返回-1
//findIndex()他返回的是下标,没有找到的话返回undefined
3、对象的扩展
对象的简洁表示法
如果对象的属性和值一样的话可以写成let obj = {a};函数的话可以写成handler(){...};
Object.assign():对象的合并。将一个对象里的所有可以枚举的属性,复制到另一个对象
let obj1 = {x:1};
let obj2 = {y:1};
Object.assign(obj1,obj2);
console.log(obj1); //{x:1,y:1}
Object.is()看俩个值是否一样,返回布尔值
console.log(Object.is(1,1)); //true
console.log(Object.is(Infinity,-Infinity)) //false
console.log(Object.is(NaN,NaN)); //true
console.log(Object.is(-0,+0)); //false
四、函数的扩展
1、函数的参数指定默认值
function handler(x,y = 1){ //y设置了一个默认值1
console.log(x + y);
}
handler(3); //
2、rest参数
rest参数的形式是"...变量名",获取函数多余的参数,这样就不需要arguments对象了,rest参数搭配的变量是一个数组,该变量将多余的参数放入数组里
function hander(...arr) { //可以在arr前面加参数,但是后面不可以加参数
var sum = 0;
for(var i=0;i<arr.length;i++){
sum += arr[i];
}
console.log(sum);
}
hander(1,2,3) //
3、箭头函数
const hander2 = function (x) { //普通函数
return x;
}
const hander1 = x => x; //箭头函数
console.log(hander1(1))
console.log(hander2(1))
//俩函数是一样的
箭头函数里没有自己的this对象,使用的时候,里面的this就是定义环境的对象,而不是使用时的对象
箭头函数里没有arguments对象,可以有rest
箭头函数不可以用作构造函数,不可以使用new操作,否则会报错
箭头函数不能用作Generator函数
ES6的小知识(后半部分)的更多相关文章
- 3星|《腾讯产业森林:AI时代的创业密码》:后半部分是较详细的创业指南,前面泛泛介绍腾讯、AI
腾讯产业森林:AI时代的创业密码 前半部分泛泛介绍腾讯对创业者的支持,腾讯支持的创业项目的案例.AI的一些基本介绍,后半部分是比较详细的写给创业者的各阶段行动与选择的指南. 总体评价3星,有一些参考价 ...
- es6 一些小知识
本人最近被es6感兴趣了,学习一些,以下就是自己总结的一些小知识 1.当你在百度输入"es6"关键字,点击进入es6入门,首先你需要知道怎样学习的顺序,先看第21章Module语法 ...
- ES6的小知识(前半部分)
一.let与const的使用 let:用来声明一个变量,与var类似 1.用let声明的变量,所声明的变量只在命令所在的代码块内有效 function hander(){ let a = 10; co ...
- 后半部分样式和JS前半部分脚本语言
样式 剩余样式: 1.<div style=display:"none"></div>:nono 是隐藏该元素内容,block是显示该元素内容 2.< ...
- C++PRIMER第二章前半部分答案
C++PRIMER第二章前半部分答案 哈哈哈,为什么是前半部分呢,后半部分还在学习中,重新系统性的学习c++,共同进步嘛,不多说,跟我一起来看看吧,第三章开始才是新手收割的时候,慢慢来~~ 2.1&a ...
- Unicode和汉字编码小知识
Unicode和汉字编码小知识 将汉字进行UNICODE编码,如:“王”编码后就成了“\王”,UNICODE字符以\u开始,后面有4个数字或者字母,所有字符都是16进制的数字,每两位表示的256以内的 ...
- 12个你未必知道的CSS小知识
虽然CSS并不是一种很复杂的技术,但就算你是一个使用CSS多年的高手,仍然会有很多CSS用法/属性/属性值你从来没使用过,甚至从来没听说过. 1.CSS的color属性并非只能用于文本显示 对于CSS ...
- 【C#小知识】C#中一些易混淆概念总结(二)--------构造函数,this关键字,部分类,枚举 分类: C# 2014-02-03 01:24 1576人阅读 评论(0) 收藏
目录: [C#小知识]C#中一些易混淆概念总结--------数据类型存储位置,方法调用,out和ref参数的使用 继上篇对一些C#概念问题进行细节的剖析以后,收获颇多.以前,读书的时候,一句话一掠而 ...
- Django 2.0.7 使用小知识
Django 2.0.3 使用小知识 运行环境: Python 3.6.4 Django 2.0.7 Django Admin中model显示为中文 定义model时,定义一个Meta对象,设置需要显 ...
随机推荐
- Android100【申明:来源于网络】
Android100[申明:来源于网络] 地址:http://www.android100.org/html/201406/11/23770.html
- python----运行机制
Python 是一门解释型的编程语言,因此它具有解释型语言的运行机制. 计算机程序,其实就是一组计算机指令集,能真正驱动机器运行的是机器指令,但让普通开发者直接编写机器指令是不现实的,因此就出现了计算 ...
- java中基本类型double和对象类型Double
Double.valueOf(str)把String转化成Double类型的对象比如Stirng str="1.0";那么Double.valueOf(str)等价于new Dou ...
- TypeError: object() takes no parameters
1.定义了类,在类中实现函数功能,但是需要传参数,我在类中没有建立__init__(self,) 导致没法传参.
- daemon函数详解
https://blog.csdn.net/xinyuan510214/article/details/50903280
- linux下查看网卡速率
转自:http://blog.csdn.net/liugongfeng/article/details/50263733 我们都知道ifconfig -a 可以列出所有网卡,但是怎么判读是千兆网卡还是 ...
- 《linux就该这么学》第九节课:第七章,RAID阵列和LVM逻辑卷技术
笔记 (借鉴请改动) 7.1.RAID(独立冗余磁盘阵列) 常见的几种RAID:RAID0,RAID1,RAID5,RAID10 raid0 实现写入速度但安全性略低. raid1 实现了速度和 ...
- centos共享目录
使用VirtualBOX自带的共享文件夹功能 运行环境: - 宿主机:windows 10 - 虚拟机:CentOS 7(我当初是按照Ubuntu环境下的教程弄的,所以其他Linux版本也可以参考 ...
- Py't'hon之csv,ini&序列化,反序列化
1.csv文件简介 csv是一个被行分隔符,列分隔符划分成行和列的文本 csv不指定字符编码 行分隔符为\r\n,最后一行可以没有换行符 列分隔符常为逗号和制表符 每一行称之为record from ...
- BeautifulReport--适用于unittest自动化测试的可视化报告
安装: 因为是由大神分享的,可以直接在github<https://github.com/TesterlifeRaymond/BeautifulReport>上下载 git clone g ...