zoukankan      html  css  js  c++  java
  • ES6笔记整理

    ES6笔记整理

    let与const

    let是变量,有块级作用域。const是常量。

    const注意事项:

    1. 使用const不能为空,必须进行赋值

    2. 一旦const修饰的标识符被赋值后,就不能在更改

    3. 常量的定义是对象(也就是内存地址)不能修改,但对象内部的属性可以更改

    4. 如果内部的属性值也不希望改变,可以使用

      const person={
      	name:'vicer',
      	age:18
      }
      
      const vicer = Ojb.freeze(person) 
      vicer.age=20    //修改失败
      

    建议:
    在ES6开发中,优先使用const, 只有需要改变某一个标识(zhi)符的时候才使用let.

    var与let/count的区别

    var拥有自己的function scope

    在for循环中使用var定义的i。使用setTimeout时,打印i的值为循环最大值。

    for(var i=0;i<10;i++){
    	setTimeout(function(){
    		console.log(i)	//打印10遍10
    	},1000)
    }
    

    因为setTimeout在异步队列中属于宏任务,同步任务执行完成后进入主线执行任务
    使用let来声明for循环时,i属于块级作用域,所以i会正常打印

    字符串模板 ,反引号

    Tab上面的点 ` ,来定义字符串,和普通的引号区别是可以换行

    字符串模板中间还可以添加变量

    const name = 'vicer'
    
    const helloName = `my name is ${name}`
    

    JSON的序列化与反序列化

    json标准写法 '{"a":0,"b":"name"}'

    • JSON序列化

      JSON.stringify()
      在需求中一般需要发送数据,我们需要把数据序列化,也就是转成标准JSON字符串

      const json = {a:0,b:'vicer'}
      console.log(JSON.stringify(json))	//{"a":0,"b":"vicer"}
      
    • JSON反序列化

      JSON.parse()
      把字符串转化成json

      const json = '{"a":0,"b":"vicer"}';
      console.log(JSON.parse(json))	//{a: 0, b: "vicer"}
      

    对象字面量增强写法

    const name = 'vicer'
    //我想把name赋值到下面的对象中去
    
    //es5写法
    const obj = {
    	name:name
    }
    //es6写法
    const obj = {
    	name
    }
    

    对象的解构

    当使用一个对象时,我们可以通过 如obj.name获取其中的属性

    但我们还有一种方法,就是直接传入一个对象进去,
    这样我们就可以直接使用对象

    let json = {a:'1',b:'2',c:'3'}
    let json2 = {
    ...json,
    d:'4'
    }
    

    数组的解构

    当我们需要使用数组时,除了把数组for循环遍历出来,还有一种写法

    //数组展开1
    let arr = [1,2,3,4]
    console.log(...arr)	//1 2 3 4
    
    //展开方式2
    let [a1,a2,...a3] = [1,2,3,4]
    console.log(a2)		//2
    
    //数组合并
    let arr1 = [1,2,3]
    let arr2 = [4,5,6]
    let allArr = [...arr1,...arr2]
    
    //数组收集
    function test(a,b,...c){
    console.log(a,b,c)
    }
    test(1,2,3,4,5,6,7)	//1,2,Array
    

    结构赋值

    1. 两边结构必须一样
    2. 右边必须是一个东西
    3. 赋值和解构必须一样
    //对象另一侧也是对象
    let str = {a:1,b:2,c:3}
    let {a,b} = str
    //console.log({a,b})
    
    //数组另一侧也是数组
    let arr = [1,2,3]
    let [x,y] = arr;
    //console.log([x,y])
    

    函数默认值

    在我们定义函数传递参数的时候,可以给一个形参传递一个默认值

    function test(name,age=18){
      //之前的方式
      //age = age || 18
      console.log(name,age)
    }
    test('vicer')
    //vicer 18
    

    这里默认值可以时任意类型,也可以是一个表达式,

    function test(name,age = anotherFun()){
      console.log(name,age)
    }
    
    function anotherFun(){
      return 18;
    }
    test('vicer');
    //vicer 18
    

    箭头函数

    函数的三种方式:

    1. 声明定义
      const a = function(){}

    2. 对象字面量定义函数

      const b ={
      		b2(){}
      }
      
    3. 箭头函数
      const c = () => {}

      当需要函数作为参数传入到另一个函数时,使用箭头函数最多

    箭头函数传参与返回值

    1. 当传的参数只有一个时可省略括号()

      const d = n => {
      		return n+n
      }
      
    2. 当箭头函数只有一行时必须省略花括号
      const e = n => n+n
      注:省略花括号{}时无需再写return,系统会自动返回值

    箭头函数的this使用

    正常情况下this是谁调用我我指向谁。

    问题:箭头函数中this是如何查找的?

    答案1:在外层作用域中,逐层查找,直到有this定义。也就是指向作用域中最近this
    答案2:自己理解:当前代码块中,外层代码块被谁调用就指向谁,没有找到,就继续向外查找

    const obj = {
      a(){
        console.log(this);//obj  谁调用我指向谁
        setTimeout(function(){
    	  console.log(this)// window
    	  //因为这里call函数,传入一个window。所以指向this
        },100);
        setTimeout(() =>{
    	  console.log(this)//obj
    	  //在外层作用域中,逐层查找,直到有this定义。也就是指向作用域中最近this
        },100);
      }
    }
    obj.a();
    

    promise异步封装

    一般情况下有异步操作时,使用Promise对这个异步操作进行封装。

    • Promise内部执行回调函数,在执行传入的回调函数时还会传入两个参数,resolve,reject。而这两参数本身又是函数

    • 在请求成功时调用resolve,参数默认传入到then中处理。

    • 在请求失败时调用reject,参数默认传入到catch中处理。

    简而言之:Promise是一个优雅的函数,在内部判断成功或失败,成功调用then处理,失败调用catch处理。

    两种写法

    1. resolve调用then,reject调用catch

      new Promise((resolve, reject)=>{
        setTimeout(()=>{
          // resolve('hello word');
          reject('error message')
        },1000)
      }).then((data)=>{
        console.log(data);
      }).catch(err =>{
        console.log(err);
      })
      
    2. 都写在then中

      new Promise((resolve, reject)=>{
        setTimeout(()=>{
          // resolve('hello word')
          reject('error message')
        },1000)
      }).then((data)=>{
        console.log(data);
      },(err)=>{
        console.log(err);
      })
      

    promise的简写

    当promise只有第一步进行异步操作,接下来操作不是异步时,可以进行代码简写

    • 一般简写方式

      new Promise((resolve, reject)=>{
        setTimeout(()=>{
          resolve('hello word')
        },1000)
      }).then((data)=>{
        console.log(data);
        //成功回调简写
        // return Promise.resolve(data+111)  
        //失败回调简写
        return  Promise.reject('error message')
      }).then((data)=>{
        console.log(data)
      }).catch(err =>{
        console.log(err);
      })
      
    • 超级简写方式

      new Promise((resolve, reject)=>{
        setTimeout(()=>{
          resolve('hello word')
        },1000)
      }).then((data)=>{
        console.log(data);
        //成功回调简写
        // return data+111
        //失败回调简写
        throw  'error message'
      }).then((data)=>{
        console.log(data)
      }).catch(err =>{
        console.log(err);
      })
      

    promise.all的使用

    当我们需要两个异步操作同时完成才能返回结果时,一般需要用到all方法。

    all中放的是数组,如promise.all([])

      Promise.all([
        new Promise((resolve, reject) => {
          setTimeout(()=>{
            resolve({name:'vicer',age:18})
          },1000)
        }),
        new Promise((resolve, reject) => {
          setTimeout(()=>{
            resolve({name:'lily',age:19})
          },2000)
        })
      ]).then(results =>{
        console.log(results);	//返回的是数组
      },reject =>{
    	  console.log(reject)
      })
    

    promise结合jquery.ajax

    promise与$.ajax的结合使用

    我们首先看下promise与$.ajax的结合使用

    let p = new Promise((resolve, reject) => {
    	$.ajax({
    		url: './text/1.txt',
    		dataType: 'json',
    		success(res) {
    			resolve(res)
    		},
    		error(err) {
    			reject(err)
    		}
    	})
    })
    
    p.then(res =>{
    	console.log(res)
    },err =>{
    	console.log(err)
    })
    

    我们都知道promise非常出名,那么ajax作者知道嘛?

    答案是肯定的,在$.ajax中也可以使用then来接收成功回调

    $.ajax({
    	url: './text/1.txt',
    	dataType: 'json'
    }).then(res => {
    	console.log(res)
    }, err => {
    	console.log(err)
    })
    

    有人可能会好奇,ajax既然存在then,为什么还要使用promise。因为请求参数时不可能只请求一个参数,可能会请求多个,所以需要用到promise.all

    promise.all与$.ajax的结合使用

    这里直接上源码对比原来的promise.all和现在的使用区别

    let p = Promise.all([
    	//原来的promise.all的使用方法
    	new Promise((resolve, reject) => {
    		$.ajax({
    			url: './text/1.txt',
    			dataType: 'json',
    			success(res) {
    				resolve(res)
    			},
    			error(err) {
    				reject(err)
    			}
    		})
    	}),
    	//在得知$.ajax的秘密之后
    	$.ajax({url: './text/2.txt',dataType: 'json'}),
    	$.ajax({url: './text/3.txt',dataType: 'json'})
    ])
    
    p.then(([data1,data2,data3]) => {
    	console.log(data2)	
    }, err => {
    	console.log(err)
    })
    

    promise.race的使用

    race竞速的意思,数据请求中谁先完成我使用谁。
    只返回一个数据
    用途:适合不同接口但数据相同

    Promise.race([
    	$.ajax({
    		url: './text/1.txt',
    		dataType: 'json'
    	}),
    	$.ajax({
    		url: './text/2.txt',
    		dataType: 'json'
    	})
    ]).then(res =>{
    	console.log(res)
    })
    

    promise.finally介绍

    所有参数都请求完成后执行的操作(不论成功失败)

    async/await异步操作

    • 普通函数

      一直执行,直到结束

    • async函数

      函数能够“暂停”

    简单介绍异步函数:

    同步的写法,异步的操作

    同步的写法,异步的操作

    async  function show(){
    	let a = 1;
    	let b = 2;
    	let c = await $.ajax({url: './text/1.txt',dataType: 'json'})//await后面也可以跟一个promise,等promise完成后再执行
    	alert(a+b+c[0])
    }
    show()
    

    异步函数有个缺点,加入操作出错了,我想捕获异步函数,该怎么做

    使用try和catch

    async  function show(){
    	let a = 1;
    	let b = 2;
    	try{
    		let c = await $.ajax({url: './text/1.txt',dataType: 'json'})
    		alert(a+b+c[0])
    	}catch(e){
    		alert(读取失败)
    	}
    }
    show()
    

    ES5面向对象

    首先说一下es5的面向对象写法,方法多,而且类与构造函数分不清

    function Person(name,age){
    	this.name=name;
    	this.age=age;
    }
    Person.prototype.showName = function(){
    	alert(this.name)
    }
    Person.prototype.showAge = function(){
    	alert(this.age)
    }
    
    const a = new Person('vicer',18);
    a.showAge();
    a.showName();
    

    ES6面向对象

    面向对象

    class 定义类
    constructor 定义构造函数
    方法直接定义在类里面,方便管理。

    class Person {
    	constructor(name, age) {
    		this.name = name;
    		this.age = age;
    	}
    	showName = function () {
    		alert(this.name)
    	}
    	showAge = function () {
    		alert(this.age)
    	}
    }
    
    const a = new Person('vicer', 18);
    a.showAge();
    a.showName();
    

    get和set的使用

    在class中我们可以使用get和set获取和设置属性

    class Chef{
    	constructor (foods){
    		this.foods = foods;
    		this.dish = []
    	}
    	get menu(){
    		return this.dish
    	}
    	set menu(dish){
    		this.dish.push(dish)
    	}
    }
    
    let a = new Chef()
    
    console.log(a.menu = '鸡蛋')	//设置属性
    console.log(a.menu = '青椒')
    console.log(a.menu)			//获取属性
    

    staitc静态方法

    static静态方法就是不需要实例化就可以使用的方法

    class Chef{
    	constructor (foods){
    		this.foods = foods;
    	}
    	static cook(food){
    		console.log(food)
    	}
    }
    console.log(Chef.cook('西红柿'))
    

    类的继承

    extends 继承
    super 父类/超类

    继承的好处:

    1. 省事,直接把父类的属性和方法拿过来用
    2. 在写extends时父类的方法自动就添加了过来,通过super拿到父类的属性
    3. 扩展,给父类添加某种方法的时候子类都会有
    class Person {
    	constructor(name, age) {
    		this.name = name;
    		this.age = age;
    	}
    	showName = function () {
    		alert(this.name)
    	}
    	showAge = function () {
    		alert(this.age)
    	}
    }
    
    class Worker extends Person {	//继承person
    	constructor(name, age, work) {
    		super(name, age)		//获取父类
    		this.work = work
    	}
    	showWork(){
    		alert(this.work)
    	}
    }
    
    const w = new Worker('jeck',20,'工人')
    w.showName();
    w.showAge();
    w.showWork();
    

    set的使用

    set有点像数组,但是里面不能放重复的东西

    • add 添加数组
    • size 获取length
    • has 检查是否拥有某个值
    • forEach 遍历数组
    • delete 删除其中某个值
    • clear 清空数组
    let arr = new Set('123');
    console.log(arr)	//{"1", "2", "3"}
    console.log(arr.add('4'))	//{"1", "2", "3", "4"}
    console.log(arr.has('3'))	//true
    arr.forEach(res =>{
    	console.log(res+'a')		//1a 2a 3a 4a
    })
    arr.delete('2')
    console.log(arr)	//{"1", "3", "4"}
    arr.clear()
    console.log(arr)	// {}
    

    map的使用

    map和set的区别是,里面是使用键值对的形式进行储存数据

    用法和set差不多,直接上源码

    let food = new Map();
    let fruit = '水果',cook = function(){},dessert = '甜点';
    food.set(fruit,'柠檬')	
    food.set(cook,'eating')
    food.set(dessert,'甜甜圈')	
    console.log(food)			//{"水果" => "柠檬", ƒ => "eating", "甜点" => "甜甜圈"}
    console.log(food.size)//3
    food.delete(fruit)
    console.log(food.has(fruit))//false
    food.clear()
    console.log(food)	//{}
    

    ES7

    幂运算

    let a = 3;
    alert(a**2);	//3的2次方
    

    Array.includes

    查找数组是否存在

    let arr = [1,2,3,4];
    
    //indexOf是用来查找下标
    //console.log(arr.indexOf(2) != -1 )	
    
    //includes是用来查找是否存在
    console.log(arr.includes(2))
    

    迭代器

    迭就是轮流的意思,代就是交换。
    迭代就是轮流交换的意思。

    每次执行的时候有两个对象

    //value 返回的值。  dong 还有没有可迭代的东西。有返回false
    {value:xx,done:true/false}
    

    里面还有一个next函数,用来迭代下次的value

    手写迭代器

    function chef(foods){
    	let i = 0;
    	return {
    		nest(){
    			let done = (i>=foods.length);
    			let value = !done ? foods[i++] : undefined;
    			return{
    				value:value,
    				done:done
    			}
    		}
    	}
    }
    
    let iterators = chef(['西红柿','鸡蛋'])
    console.log(iterators.nest())	//{value: "西红柿", done: false}
    console.log(iterators.nest())	//{value: "鸡蛋", done: false}
    console.log(iterators.nest())	//{value: undefined, done: true}
    

    手写迭代器有点麻烦,但要理解其中原理。
    我们可以使用generators生成迭代器

    1. 在函数后面加*号
    2. 使用yield添加要迭代的item
    3. 传入参数并调用next
    function* chef(foods){
    	for(let item of foods){
    		yield item;
    	}
    }
    
    let iterators = chef(['西红柿','鸡蛋'])
    console.log(iterators.next())	
    console.log(iterators.next())	
    console.log(iterators.next())	
    
  • 相关阅读:
    随手记几个容易被忽略的bug
    fiddler常见应用场景
    浅谈软件测试流程
    http抓包实战之http协议初始、fiddler初识
    http之header详解
    http协议基础(一)
    Fiddler抓包工具总结二(转自小坦克)
    接口测试总结
    [Python][爬虫]利用OCR技术识别图形验证码
    [总结]JS在Selenium中的使用
  • 原文地址:https://www.cnblogs.com/lovecode3000/p/12324289.html
Copyright © 2011-2022 走看看