エラーメッセージを保持するカスタムApp.Error
オブジェクトを使用できます。また、ember-dataの使用を計画している場合は、検証についての説明がありますhttps://github.com/emberjs/data/pull/130。また、優れたEmber.jsアドオンには検証拡張機能があります:https ://github.com/capitainetrain/ember-addons/tree/master/packages/ember-validators/lib 。
これが私が念頭に置いていることです。http ://jsfiddle.net/pangratz666/kQJ2t/を参照してください。
ハンドルバー:
<script type="text/x-handlebars" data-template-name="edit" >
name: {{view App.TextField valueBinding="content.name" propertyName="name" }}</br>
age: {{view App.TextField valueBinding="content.age" propertyName="age" }}</br>
<button {{action "save"}}>save</button>
</script>
JavaScript:
App.Error = Ember.Object.extend({
isError: function(propertyName) {
return !Ember.empty(this.getErrorMessage(propertyName));
},
getErrorMessage: function(propertyName) {
return this.get(propertyName);
}
});
App.ErrorMixin = Ember.Mixin.create({
classNameBindings: ['isError:error'],
errorBinding: 'parentView.error',
template: Ember.Handlebars.compile('{{#if isError}}{{errorMessage}}{{/if}}'),
isError: function() {
var error = this.get('error');
return error && error.isError(this.get('propertyName'));
}.property('error', 'propertyName'),
errorMessage: function() {
var error = this.get('error');
if (error) {
var propertyName = this.get('propertyName');
return error.getErrorMessage(propertyName);
}
}.property('error', 'propertyName')
});
App.TextField = Ember.TextField.extend(App.ErrorMixin);
次に、エラーオブジェクトは次のように作成されます。
Ember.View.create({
templateName: 'edit',
contentBinding: 'App.obj',
save: function() {
var content = this.get('content');
var error = this.get('error');
if (error) {
error.destroy();
}
error = App.Error.create();
if (content.get('age') <= 100) {
error.set('age', 'sorry, you are not wise enough');
}
if ('Chuck Norris' === content.get('name')) {
error.set('name', 'yeah, and i am the queen of england');
}
this.set('error', error);
}
}).append();