我正在尝试将 ember js 与 jquery mobile ttps://github.com/LuisSala/emberjs-jqm 一起使用
如何在 ember 工具中扩展自定义视图。我尝试了这样的事情,但没有奏效。
var MobileBaseView = Ember.View.extend({
attributeBindings:['data-role']
});
module.exports = MobileBaseView;
和
var MobileBaseView = require('MobileBaseView');
var PageView = MobileBaseView.extend({
'data-role': 'page'
});
module.exports = PageView;
那没起效
*更新* * ** * 在执行主销的建议后(谢谢)。我观察到多级扩展在我的情况下不起作用。
我有
移动基础视图:
var MobileBaseView = Ember.View.extend({
attributeBindings:['data-role']
});
module.exports = MobileBaseView;
工具栏基本视图:
var ToolbarBaseView = App.MobileBaseView.extend({
attributeBindings:['data-position'],
'data-position': function() {
if (this.get('isFullScreen')) {
return 'fullscreen'
}
if (this.get('isFixed')) {
return 'fixed'
}
return ''
}.property('isFixed', 'isFullScreen').cacheable(),
isFixed: true,
isFullsScreen: false
});
module.exports = ToolbarBaseView;
和我模板中的一行
{{view App.ToolbarBaseView}}
这项工作很好
但是一旦我再添加一个视图 标题视图
var HeaderView = App.ToolbarBaseView.extend({
'data-role': 'header'
});
module.exports = HeaderView;
并添加行
{{view App.HeaderView}}
我收到错误 Uncaught TypeError: Cannot call method 'extend' of undefined
解决了
让这个与 ember 应用程序包一起工作
import ToolbarBaseView from 'appkit/views/toolbar_base_view';
var HeaderView = ToolbarBaseView.extend({
'data-role': 'header'
});
export default HeaderView;