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

          



最新文章

  1. UIView的几个layout方法
  2. 安装金山WPS2013造成的HTML5 file.type值异常
  3. about shell
  4. Known plaintext attack
  5. js 倒计时 倒计时60秒
  6. Android Application对象必须掌握的七点
  7. spring06Aop
  8. SQL按汉语拼音首字母排序
  9. Python 中的重点来了 : 迭代器 生成器
  10. Pi Hybrids问题
  11. List根据对象的两个字段进行排序,并且有一个倒序
  12. 【ORACLE】解锁scott帐号
  13. Python爬虫学习——使用selenium和phantomjs爬取js动态加载的网页
  14. PHP手册-函数参考-加密扩展
  15. CPU的硬件结构和汇编语言
  16. 第三百六十二节,Python分布式爬虫打造搜索引擎Scrapy精讲—elasticsearch(搜索引擎)基本的索引和文档CRUD操作、增、删、改、查
  17. 提取win10默认锁屏壁纸
  18. js 变量、函数提升 与js的预编译有关
  19. ETL学习整理 PostgreSQL
  20. 四、jenkins+postman+newman环境搭建

热门文章

  1. 3D打印技术的火爆,真的会让传统模具行业没落吗?
  2. 【LeetCode】课程表 II
  3. 小程序跳坑之JSON字符串转换JSON对象
  4. Elasticsearch 集群 - 健康检查
  5. JavaScript使浏览器不使用缓存
  6. 浏览器输入URL后,发生了什么?(打开一个网页会使用哪些协议?)
  7. 动态添加,删除class样式
  8. UVA - 1611 Crane(起重机)(贪心)
  9. 在mac电脑的terminal里该如何运行c语言
  10. MVC学生管理系统-阶段III(删除学生信息)