javascript - 使用转义键取消 Ember TextView 中的操作

标签 javascript ember.js

当用户在输入字段中按下转义键时,如何让 Ember 触发 Controller 操作?

给定以下应用程序代码:

App = Ember.Application.create();

App.IndexRoute = Ember.Route.extend({
  model: function () {
    return {foo: "bar"};
  }
});

App.IndexController = Ember.ObjectController.extend({
  actions: {
    done: function () {
      console.log("done");
    },
    cancel: function () {
      console.log("cancel");
    }
  }
});

以及以下 HTML:

<body>
  <script type="text/x-handlebars" data-template-name="application">
    {{outlet}}
  </script>
  <script type="text/x-handlebars" data-template-name="index">
    {{input value=foo action="done" cancel="cancel"}}
  </script>
</body>

我希望 Controller 中的取消操作被触发,但我得到的是一个错误:Property 'cancel' of object [object Object] is not a function

Here's a JSBin用上面的代码来说明。我怎样才能使它工作?

最佳答案

它的文档不是很多,但是看到代码... https://github.com/emberjs/ember.js/blob/v1.1.2/packages/ember-handlebars/lib/controls/text_support.js#L106-L117

你应该这样定义你的 Handlebars

{{input value=foo enter='done' escape-press='cancel'}}

JsBin http://jsbin.com/ObucELO/1/edit

关于javascript - 使用转义键取消 Ember TextView 中的操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19926191/

相关文章:

ember.js - 使用 Ember 保存不成功时显示错误

model-view-controller - Ember.js:如何访问 CollectionView 中的特定项目?

Javascript:Mathfloor 仍然生成 0

javascript - 如何将字符串中的字符列表替换为相应的字符列表

javascript - Ember 和 Handlebars 迭代集合数组

javascript - 在 Ember.js 中访问父路由模型

javascript - 如何获取/设置当前页面 URL(跨时空浏览器版本)

javascript - react 使用 img onerror

javascript - 将十进制值从月数转换为天数/周数的数学函数