js类的constructor中不支持异步函数吗?

Posted wxsloveyou

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js类的constructor中不支持异步函数吗?相关的知识,希望对你有一定的参考价值。

解决方案:

1.如果是普通函数,可以用async 和await来解决你的问题
但你这个是在constructor里,constructor 的作用是返回一个对像实例,如果加了async就变成返回一个promise了,所以这个方法行不通,因为做不到既返回一个promise又返回一个object 实例

eg:

class ShopCarTool{
      constructor(store,from_async){
       // var shopCar = DB.getItem(‘shop-car‘).toJson()// 从localStorage获取
        /* 从服务器获取 */
        if(!from_async){
          DB.setItem(‘shop-car‘, JSON.stringify(shopCar = {}))
        }
        this.$store = store
        this.shopCarDB = from_async
      }
      static async build(store){
          let data = await axios.get(url)
          return new ShopCarTool(store,async_result);
      }
      length() {//获取购物车商品数量小角标
        var n = 0;
        for(var i in this.shopCarDB){
          n += this.shopCarDB[i].length
        }
        return n
      }
    }
所以你哪你要实例化也改成(tips: 代码没有经过严格验证,就是这么个意思,)
var tool = await ShopCarTool.build(store)
 


以上是关于js类的constructor中不支持异步函数吗?的主要内容,如果未能解决你的问题,请参考以下文章

js深入理解构造函数和原型对象

第186天:js深入理解构造函数和原型对象

js中函数的prototype.constructor是指向函数本身,它有啥用

js异步函数队列

React中的constructor和super+生命周期

JS报错:Uncaught TypeError: Illegal constructor