入门指南 获取Ember 概念 对象模型 应用 模板 路由 组件 控制器 模型 视图 枚举 测式 配置Ember.js COOKBOOK 理解Ember.js

发布于 2015-08-18 16:36:16 | 285 次阅读 | 评论: 0 | 来源: 网络整理

修改属性

一旦一条记录已经加载进来,你就可以开始 修改它的属性(attributes)了。属性(attributes)和Ember.js中对象的普通属性(properties)差不多。(译注:这 两个词我都译成了属性,读者自行判定其中潜在的区别)。修改记录就是修改记录的属性。

 
1
2
3
var tyrion = this.store.find('person', 1);
// ...after the record has loaded
tyrion.set('firstName', "Yollo");
 

Ember.js能提供的所有便利在修改属性都适用。比如,你可以用Ember.ObjectincrementProperty助手方法。

 
1
2
person.incrementProperty('age');
// Happy birthday!
 

你可以通过isDirty属性来判断一条记录是否被更改,且尚未保存。此外使用changedAttributes函数还可以查看记录哪些部分被修改了,以及这些部分被修改前的值是什么。changedAttributes返回一个对象,其键值是被改变的属性,而值是一个数组[oldValue, newValue]

 
1
2
3
4
5
person.get('isAdmin');      //=> false
person.get('isDirty');      //=> false
person.set('isAdmin', true);
person.get('isDirty');      //=> true
person.changedAttributes(); //=> { isAdmin: [false, true] }
 

此时,可以通过save()将改变持久化,也可以回滚做的改变。调用rollback()会将所有changedAttributes设置回其原来的值。

 
1
2
3
4
5
6
7
8
person.get('isDirty');      //=> true
person.changedAttributes(); //=> { isAdmin: [false, true] }

person.rollback();

person.get('isDirty');      //=> false
person.get('isAdmin');      //=> false
person.changedAttributes(); //=> {}
 
最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务