dart - 为自定义组件提供回调

标签 dart angular-dart

我制作了一个自定义组件,它基本上包装了 d3 折线图。现在我希望能够为点击图表中的线条注册回调。

我给了组件一个@NgCallback参数,然后我将事件发送到:

class NetworkSummaryComponent implements NgShadowRootAware {
  @NgCallback('callback')
  Function callback;

  void onShadowRoot(ShadowRoot shadowRoot) {
    ...
    chart.callMethod('listen', ['line-click', (ev) {
        var name = ev.callMethod('getLineName');
        print(name);
        callback({'name': name});
    }]);
  }
}

使用组件时,我指定 Controller 的一个函数作为回调:

<network-summary
    ...
    callback="ctrl.lineClicked">
</network-summary>

但是,该函数从未被实际调用,因为我知道回调是从 JS 端到达的,因为第一个代码片段中的打印已执行。

如果我将属性指定为 callback="ctrl.lineClicked()" 我会得到一个奇怪的异常:

参数不匹配的闭包调用:函数“call”

我找不到任何关于如何正确执行回调的官方文档,所以我不确定我做错了什么。有什么想法吗?

最佳答案

事实证明,我必须在属性中显式命名预期的参数:

<network-summary
    ...
    callback="ctrl.lineClicked(name)">
</network-summary>

希望这对下一个遇到此问题的人有用。

关于dart - 为自定义组件提供回调,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22915977/

相关文章:

dart - flutter : How to calculate value from textfields in listview.构建器

flutter - 第21行的pubspec.yaml的第8列错误:版本约束无效:无法解析版本 “flutter”。 “flutter”的文字未知

dart - 使用 <content> 呈现嵌入内容时的范围问题

dart - AngularDart 指令列表?

dart - Pub 失败,[1] 解决依赖关系... code_transformers 的版本约束不兼容

flutter - Flutter-在.then()函数外部的getter中检索值

flutter - 如何在Flutter中使用SharedPreferences保存List <List <String >>

web-applications - Dart一页应用程序:不使用AngularDart进行路由

flutter - 如何显示 double 到 2 个小数点?

dart - 编译dart以分离js文件