有没有办法异步初始化 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);
                    });
                })
        }
    }
}

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...