微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

有没有办法异步初始化 Viewmodel (KnockoutJS)

如何解决有没有办法异步初始化 Viewmodel (KnockoutJS)

我想异步初始化一个 viewmodel。我的意思不是异步加载viewmodel,我已经管理(见下面的代码)。

viewmodel 将被异步加载一次。之后,我想根据提供给viewmodel的参数做一些异步操作。看起来在获得参数后,您必须同步返回 viewmodel,不支持承诺/回调系统。 看下面的代码


const defaultLoader: KnockoutComponentTypes.Loader = {
  loadviewmodel: function (name,templateConfig,callback) {

    //if there is a 'fromUrl' property
    if (templateConfig.fromUrl) {

      //use import to load the code 
      import(templateConfig.fromUrl)
        .then(module => {

          //viewmodel is loaded asynchronous (one time!)
          callback( (params,componentInfo) => {
            
            //initialize the viewmodel
            const model = module.default(
              params,componentInfo)
          
              //I can only return synchronously here:
            return model
          });
        })
    } 
  }
}

我想做的是使用 async/await 来表示它必须在一切解决之前等待:

          //viewmodel is loaded asynchronous (one time!)
          callback(async (params,componentInfo) => {

            //initialize the viewmodel
            const model = module.default(
              params,componentInfo)

            //I can only return synchronously here:
            return await model
          });

但后来我的 viewmodel 最终成为了承诺对象。 有关如何实现这一目标的任何建议?

解决方法

你不能从异步函数返回任何东西,但这与 Knockout 真的无关。您可以返回承诺,也可以在异步函数中调用其他函数。

为此,您应该能够在完成处理后使用 KO 的默认加载器(不要覆盖它,就像您现在所做的那样)来创建视图模型,如下所示:

const customLoader: KnockoutComponentTypes.Loader = {
    loadViewModel: function(name,templateConfig,callback) {

        //if there is a 'fromUrl' property
        if (templateConfig.fromUrl) {

            //use import to load the code 
            import(templateConfig.fromUrl)
                .then(module => {

                    //viewmodel is loaded asynchronous (one time!)
                    callback((params,componentInfo) => {

                        //initialize the viewModel
                        const model = module.default(
                            params,componentInfo)

                        ko.components.defaultLoader.loadViewModel(name,model,callback);
                    });
                })
        }
    }
}

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?