如何在Aurelia中使用aurelia-dialog插件?

时间:2015-09-05 21:23:01

标签: javascript aurelia

我在使用我的测试Aurelia应用程序设置aurelia-dialog插件(0.2.0)时遇到了麻烦。

不幸的是,详细说明如何完成此操作的README.MD文件存在一些严重漏洞。首先,它没有提到必须将aureliaDialog注入你的班级,所以我先尝试了这个:

@inject(HttpClient, DialogService)
export class MyClass{
  constructor(http, dialogService) {
    this.http = http;
    this.dialogService = dialogService;
  }
  ...
}

我尝试使用以下方法调用对话框:

this.dialogService.open({ viewModel: Prompt, model: 'Good or Bad?' })

以上导致以下错误:

Unhandled promise rejection ReferenceError: info is not defined
    at Container.invoke (http://127.0.0.1:9000/jspm_packages/github/aurelia/dependency-injection@0.10.0/aurelia-dependency-injection.js:401:30)
    at Array.<anonymous> (http://127.0.0.1:9000/jspm_packages/github/aurelia/dependency-injection@0.10.0/aurelia-dependency-injection.js:272:44)
    at Container.get (http://127.0.0.1:9000/jspm_packages/github/aurelia/dependency-injection@0.10.0/aurelia-dependency-injection.js:329:24)
    at http://127.0.0.1:9000/jspm_packages/github/aurelia/templating@0.15.1/aurelia-templating.js:3685:75
    at run (http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/es6.promise.js:91:43)
    at http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/es6.promise.js:105:11
    at module.exports (http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/$.invoke.js:6:25)
    at queue.(anonymous function) (http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/$.task.js:40:9)
    at Number.run (http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/$.task.js:27:7)
    at listner (http://127.0.0.1:9000/jspm_packages/npm/core-js@0.9.18/modules/$.task.js:31:9) Unhandled promise rejection ReferenceError: info is not defined(…)(anonymous function) @ es6.promise.js:139module.exports @ $.invoke.js:6queue.(anonymous function) @ $.task.js:40run @ $.task.js:27listner @ $.task.js:31

接下来,我尝试将插件的配置添加到我的main.js文件中:

export function configure(aurelia) {
  aurelia.use
    .standardConfiguration()
    .developmentLogging()
    .plugin('aurelia-animator-css')
    .plugin('aurelia-dialog'); // <----- this is what I added

  aurelia.start().then(a => a.setRoot());
}

现在我的应用程序根本没有启动并在尝试(和失败)启动时产生以下错误:

DEBUG [aurelia] Configured plugin aurelia-dialog. aurelia-logging-console.js:38 
DEBUG [templating] importing resources for undefined [] es6.promise.js:139 
  Unhandled promise rejection Error: Cannot read property 'querySelectorAll' of undefined(…)
  (anonymous function) @ es6.promise.js:139module.exports @ $.invoke.js:6queue.
  (anonymous function) @ $.task.js:40run @ $.task.js:27listner @ $.task.js:31

我现在不知道接下来会尝试什么。感谢您就此问题提供的任何见解。

我也希望aurelia-dialog插件的维护者修改文档,使设置过程不那么痛苦。

谢谢, 格雷格

1 个答案:

答案 0 :(得分:1)

最后,问题证明是aurelia-dialog 0.2.0中的一个错误。版本0.2.1修复了我无法自行解决的问题:https://github.com/aurelia/dialog/pull/24

我必须遵循的其他步骤 - 您需要注入DialogService类并修改main.js文件以添加配置。