class 专题

  定义 class

    //es5 类的定义  属性定义在 function 上, 方法定义在原型链上

    function foobar(){

      this.foo_ = 'foo';

      this.bar_ = 'bar';

    }

    foobar.prototype.sayHello = function(){ console.log('hello') }

    const fb = new foobar();

    fb.sayHello();

    // es6 class 语法

    class foobar2{

      constructor(){

        this.foo_ = 'foo';

        this.bar_ = 'bar';

      }

      sayHello(){ console.log('hello') }

    }

    const fb2 = new foobar2();

    fb2.sayHello();

  继承

    class father {

      sayHi(){ console.log('Hi') }

    }

    class son extends father{

      constructor () {

        super();

        this.me='son'

      }

      sayHello(){ console.log('hello') }

    }

    const son1 = new son();

    // 调用 father 类的 sayHi 方法时 找自己的原型 son.prototype 是否含有这个 方法

    // 通过查看父类的原型判断 是否调用的父类的方法 其中 son.prototype.__proto__=father.prototype

    // 通过 类名.hasOwnProperty('方法的名称') 判断是否含有该方法

    son1.sayHi();

异步专题

   javascript 中的事件循环 (不限制时间)

  物理线程的事件循环是有事件限制的

  用事件提交器 将 事件 推入事件 队列 然后 通过事件循环 处理到当前 事件时 然后处理 事件处理函数 (回调函数)

  

  Promise 语法糖 使用

    把多重的 函数 嵌套请求 写得更简单

    链式调用

    eg:多次 发起 fetch 请求

      window.fetch('//xx.com/1').then(data=>{

        window.fetch('//xx.com/2');

      }).then(data=>{

        window.fetch('//xx.com/3');

      }).then(_=>{

        console.log('ok');

      })

    eg: 异步 多次 发起 延时3s 执行函数

      function fn (){

        console.log(Date.now())

      }

      function delay3sPromise( fn ){

        return new Promise( (resolve, reject) =>{

          // resolve 通知 promise 业务代码 成果 并 返回结果

          // reject   函数执行失败 并返回错误

          setTimeout(_ => {

            try{

              const ret = fn();

              resolve(ret);

            }catch(err){

              reject(err);  //发生了错误

            }

          }, 3000)

        } )

      }

    // 调用

      delay3sPromise(fn).then(_=>{

        return delay3sPromise(fn);

      }).then(_=>{

        return delay3sPromise(fn);

      }).catch(err => {

        console.log(err);

      })

    eg: 同步 请求 处理

      function delaySame(fn){

        return new Promise(_ => {

          try{

            return Promise.resolve(data)

          }catch(err){

            return Promise.reject(err)

          }

        })

      }

      //调用

      dedelaySame(fn).then(data=>{

        console.log(data);

      }).catch(err){

        console.log(err);

      }

    要点

      Promise 一旦创建是 一定会执行的

      创建一个 Promise 只能调用一次

      Promise的 三个状态: pending (执行代码前)-> fulfilled(执行成功) | rejected(执行失败)

      try/catch 不能捕获 Promise 中的 异常(是使用 Promise 后的 catch 方法进行捕获)

        eg: new Promise(fn).catch(err=>{ console.log(err) })

      链式调用

  三种异步

    macro task  宏任务

    micro task   微任务 (优先级 比 宏任务高)

    物理线程

    eg:  同步代码先执行  同步代码后的 异步代码先执行  后执行 异步代码

      console.log(0)

      setTimeout(_=> console.log(1))  // 异步代码 宏任务

      new Promise((resolve, reject)=>{  // 该回调为 同步执行

        console.log(2)

        resolve()

        console.log(3)

      }).then(_=>{      //  异步代码  微任务

        console.log(4)

      }).then(_=>{      //  异步代码  微任务

        console.log(5)

      })

      console.log(6)

      结果: 0 2 3 6 4 5 1

  async 和 await  用法

    一种比 Promise 更好用的语法

      Promise 语法

        eg:

          function copyFile(src, dst) {

            return readFile(src).then(content => {

            return writeFile(dst, content)

          })}

          copyFile('src', 'dst')

            .then(_ => console.log('finished'))

            .catch(err => console.error(err))

      async 和 await 语法  

        1. async 函数 只有在 async 函数内使用

        2. wait 是 .then 的 语法糖

        3. async await 函数内 能使用 try catch

        async function copyFile (src, dst) {

          const content = await readFile(src)  // await 等同于使用 .then

          writeFile(dst, content)

        }

        async function writeFile(dst, content){

          console.log(dst, content);

        }

        async function readFile(src){

          console.log(src);

          return 'readFile content'

        }

        async function main () {

          try {

            await copyFile('src', 'dst')

            console.log('finished')

          } catch (err) {

            console.error(err)

          }

        }

        console.log(1);

        main();

        console.log2;

        结果: 1 src 2 (src  readFile content)  finishd

        // 解析  main 函数 内的 copyFile 会 先解析成 一个 Promise 的 同步代码 然后拼接成 .then 的 异步代码  所以会有 1 后 先输出 src 再输出 2  Promise 代码 在上面

    拓展

      callback 转 promise

        eg:

          function ajax(url, callback){ //... }   // callback

          function ajaxPromise(url){    // promise

            return new Promise((resolve, reject)=>{

              ajax(url, (err, content)=>{

                if(err){  reject(err); return }

                resolve(content)

              })

            })

          }

          ajaxPromise('xxx.com').then((content)=>{

            // 调用成功 处理

          }).catch((err)=>{

            // 调用失败 处理

          })

      promise 转 async

        sync function main(){

          try{

            const content = await ajaxPromise('xxx.com');

          }catch(err){

            console.log(err);

          }

        }

      callback 转 async

          



4. 现代 javascript class 专题 和 异步专题的更多相关文章

  1. 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求

    转http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro2/ 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求 ...

  2. [js]javascript中4种异步

    javascript中4种异步: 1.ajax 2.定时器 3.事件绑定 4,回调 定时器 //顺序执行 /* var s = 0; for (var i = 0; i < 10000; i++ ...

  3. c#封装DBHelper类 c# 图片加水印 (摘)C#生成随机数的三种方法 使用LINQ、Lambda 表达式 、委托快速比较两个集合,找出需要新增、修改、删除的对象 c# 制作正方形图片 JavaScript 事件循环及异步原理(完全指北)

    c#封装DBHelper类   public enum EffentNextType { /// <summary> /// 对其他语句无任何影响 /// </summary> ...

  4. JavaScript 文件延迟和异步加载

    JavaScript 文件延迟和异步加载 -般情况下,在文档的 <head> 标签中包含 JavaScript 脚本,或者导入的 JavaScript 文件. 这意味着必须等到全部 Jav ...

  5. Javascript的单线程和异步编程

    运行时概念 下面的内容解释了一个理论上的模型.现代 JavaScript 引擎着重实现和优化了描述的几个语义. 可视化描述 栈 函数调用形成了一个栈帧. function foo(b) { var a ...

  6. 3. 现代 javascript 数组专题 和 对象专题

    数组专题 展开运算符 使用...符号, 可以将数组"展开". 数组展开的妙用 ... eg: // 代替apply const foo = [1, 2, 3] const bar ...

  7. 2. 现代 javascript 新语法 及 对象专题

    let , const 和 var javascript 里面的作用域 一个大括号 是一个作用域 {  } var 会 在局部作用定义 被定义时 会提升作用域  如 if 的 {} 就属于 局部作用域 ...

  8. JavaScript 常用数组函数方法专题

    1. 由字符串生成数组 split() 分割字符串,并将分割的部分作为一个元素保存在一个新建的数组中. var str1 = "this is an emample to using the ...

  9. JavaScript的同步与异步

    1.手绘一张图说明. 2.为什么JavaScript是单线程(这里引用阮一峰老师的话) JavaScript的单线程,与它的用途有关. 作为浏览器脚本语言,JavaScript的主要用途是与用户互动, ...

随机推荐

  1. 网卡工作原理和wireshark混杂模式

    通过设置网卡为混杂模式就能捕获局域网内所有发包内容,包括非广播包和非发给自己主机的数据包 这是为什么呢? 即主机A发送一个数据包给主机B,我作为主机C怎么也能截获这个数据包呢,原理是什么? 我的网卡为 ...

  2. int类型和char类型的区别

    下面三个定义式的区别: int i = 1; char i = 1; char i = '1'; int用来定义整型变量,char用来定义字符型变量,要清楚的知道三个定义式的区别,可以比较它们在内存中 ...

  3. asp.net mvc邮箱激活

    1.发送邮件 public ActionResult SendEmail() { var member = dbSession.MemberRepository.LoadEntities(p => ...

  4. NRF52840与NRF52832的性能区别

    蓝牙版本的不断更新,大部分客户慢慢都向往着蓝牙5.0.当然对于前不久NORDIC刚出的蓝牙5.0 NRF52840,很多人都还不是很了解.NRF52840可以说是NRF52832的超强升级版,虽然同样 ...

  5. shell中取字符串子串的几种方式 截取substr

    shell中取字符串子串的几种方式 echo "123456789" | awk '{print substr($0,5,2)}' 截取 1)awk中函数substrsubstr( ...

  6. PHP笔记01

    php 环境 xamp wamp phpstudy等集成软件网上很多 PHP基础语法 PHP语法是以<?php开始 ?>结束的//php 文件的默认扩展名是.php 例如(用PHP输出he ...

  7. Linux基础命令层级图-01

    Linux基础命令层级图-01:

  8. taro编译的时候报 exports.pRimraf = util_1.promisify(rimraf); 错误

    C:\Users\1\AppData\Roaming\npm\node_modules\@tarojs\cli\dist\h5\helper.js:8 exports.pRimraf = util_1 ...

  9. css文本强制两行超出就显示省略号,不显示省略号

    1. 强制一行的情况很简单 overflow:hidden; //超出的隐藏 text-overflow:ellipsis; //省略号 white-space:nowrap; //强制一行显示 2. ...

  10. 【LeetCode】最小路径和

    [问题]给定一个包含非负整数的 m x n 网格,请找出一条从左上角到右下角的路径,使得路径上的数字总和为最小. 说明:每次只能向下或者向右移动一步. 示例: 输入: [ [,,], [,,], [, ...