IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> js-class异步操作-异步设置变量 -> 正文阅读

[JavaScript知识库]js-class异步操作-异步设置变量

思路:class里面异步获取数据,并设置给类里面的变量,constructor里面是不允许异步操作的,通过设置静态方法来执行异步操作,见init()

class BaseShot {
        static a = null
        static _instance = null
        constructor(props) {
          console.log(BaseShot.a)
        }
        static async init(options) {
          if(!BaseShot._instance) {
            BaseShot.a = await BaseShot.setA() // 异步数据处理
            BaseShot._instance = new BaseShot(options)
          }
          return BaseShot._instance
        }
        static setA() {
          return new Promise((resolve, reject) => {
            setTimeout(() => {
              resolve(5)
            }, 300)
          })
        }
        get a() { // 重要!
          return BaseShot.a
        }
      }
      const cfg = {
        href: 'www.baidu.com',
      }
      async function test() {
        const shot = await BaseShot.init(cfg) // 这里也是异步!
        console.log(shot.a)
      }
      test()

继承的写法:

class BaseShot {
        static a = null
        static _instance = null
        constructor(props) {
        }
        static setA() {
          return new Promise((resolve, reject) => {
            setTimeout(() => {
              resolve(5)
            }, 300)
          })
        }
        static async init(sup, options) {
          if(!sup._instance) {
            sup.a = await sup.setA()
            console.log(sup.a)
            sup._instance = new sup(options)
          }
          return PDF._instance
        }
      }
      class PDF extends BaseShot{
        constructor(props) {
          super(props)
        }
        get a() { // 重要!
          return PDF.a
        }
      }
      const cfg = {
        href: 'www.baidu.com',
      }
      async function test() {
        const pdf = await PDF.init(PDF)
        console.dir(pdf)
        console.log(pdf.a)
      }
      test()
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-09 12:31:32  更:2022-05-09 12:35:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 5:52:04-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码