我想将所有接触事件委托给定义的单击处理程序,作为iPhone和其他"触摸浏览器"的默认设备。我想出了两种方法:
1)扩展Ember.View将所有接触事件委派给点击处理程序:
Ember.View.reopen({
touchStart: function(event) {
return this.click(event);
}
});
App.SomeView = Ember.View.extend({
click: function(event) {
console.log('should be fired for click and touchstart events');
},
});
2)在(车把)模板中指定多个动作事件:
<i {{action someAction on="click,touchStart"}} ></i>
两种方法都不起作用。我想念什么?ember.button的实施相似(第18625行)。
您正在使用什么ember.js版本?以下示例可与最新的ember.js v1.0.0-pre2
一起使用,请参见http://jsfiddle.net/pangratz666666666666666bg/:
App = Ember.Application.create({});
Ember.View.reopen({
touchStart: Ember.alias('click'),
click: function() {
console.log('clicki di click OR touchi di touch');
}
});
Ember.View.create({
elementId: 'leViewId',
templateName: 'leViewTemplate'
}).append();
Ember.run.later(function() {
Ember.$('#leViewId').trigger('touchstart');
}, 500);
Ember.run.later(function() {
Ember.$('#leViewId').trigger('click');
}, 1000);
通过<i {{action someAction on="click,touchStart"}} ></i>
注册多个事件不起作用。如果要处理超过1类的事件,则应使用自定义Ember.View
。