此代码适用于ember 1.7.0:
var ViewTemplateHelper = Ember.Handlebars.makeBoundHelper(function(templateString, options) {
var dummy = Ember.View.extend({
classNames: ['view-template'],
template: Ember.Handlebars.compile(templateString)
});
var view = dummy.create();
if (options && options.hash) {
options.hash.content = template;
}
// Hack to prevent appendChild error
if (options.data.view._state === 'inDOM') {
options.data.view.rerender();
options.data.view.renderToBuffer();
}
return Ember.Handlebars.helpers.view.call(this, view, options); // undefined is not a function
});
export
default ViewTemplateHelper;
但现在在ember 1.10.0中会出现undefined is not a function
错误。
我尝试使用Ember.Handlebars.helpers.view.helperFunction.call
。
我想念什么?
答案 0 :(得分:0)
此问题的解决方案不是帮助程序,而是使用组件。
// components/content-element.js
import Ember from 'ember';
export
default Ember.Component.extend({
updateLayout: function() {
var store = this.container.lookup('store:main');
var projectId = this.get('project.id');
store.find('contentElement', {
key: this.get('key'),
project_id: projectId
}).then(function(contentElement) {
if (!Ember.isEmpty(contentElement.get('firstObject.value'))) {
var template = contentElement.get('firstObject.value');
var compiled = Ember.Handlebars.compile(template);
this.set('layout', compiled);
this.rerender();
}
}.bind(this));
}.observes('key').on('init')
});
我们将模型contentElement
用于模板。将布局设置为已编译的Handlebars后,您必须运行this.rerender();
对于组件,您必须绑定所有要使用的变量,如下所示:
{{content-element key="name.of.element" project=project}}
在这种情况下,我们在动态模板中使用project
,因此我们将其绑定。 key
用于从商店中获取正确的contentElement
。