Ember型号未更新

时间:2015-10-06 19:08:21

标签: ember.js ember-data

我有一条显示挑战列表的路线,当我创建新挑战时,记录会保留,但是当我转换回路线时,挑战列表的模型不会更新。有什么我想念的吗?

//new.js
 var challenge = this.store.createRecord('challenge', {
            name_en: this.get('model.name_en'),
            name_fr: this.get('model.name_fr'),
            description_en: this.get('model.description_en'),
            description_fr: this.get('model.description_fr'),
            end_date: this.get('model.end_date'),
            start_date: this.get('model.start_date'),
            points_cap: this.get('model.points_cap'),
            points_goal: this.get('model.points_goal'),
            challenge_type: 1,
            short_description_en: this.get('model.short_description_en'),
            short_description_fr: this.get('model.short_description_fr'),
            excluded_activities: excluded
        });

        // Persist record.
        challenge.save().then((challenge) => {
            this.transitionToRoute('challenges');
        }).catch((error) => {
            this.handleError(error, 'error.system_error');
        });

//router.js
Router.map(function() {
   this.route('challenges', function() {
   this.route('new');
   this.route('challenge', {
    path: ':challenge_id'
}, function() {
   this.route('delete');
   this.route('edit');
});

});

//challenges.js
import Ember from 'ember';
import AuthenticatedRouteMixin from 'simple-auth/mixins/authenticated-route-mixin';
import UserProfile from '../models/user-profile';

export default Ember.Route.extend(AuthenticatedRouteMixin,{

userProfile: UserProfile.create(),

model: function() {
    return this.store.query('challenge', {league_id: this.get('userProfile.league_id')});
}

});

//new challenge payload
 {  
"activity_exclusion_list":[  

],
"challenge_type":1,
"challengeUrl":null,
"end_date":"31-10-2015",
"number_participants":null,
"number_teams":null,
"points_cap":null,
"points_goal":null,
"start_date":"01-10-2015",
"leagueId":"1",
"teams":[  

],
"name_lang":{  
  "en":"New Challenge ",
  "fr":null
},
"description_lang":{  
  "en":"New Challenge",
  "fr":null
},
"short_description_lang":{  
  "en":"New Challenge",
  "fr":null
}

}

//response from new challenge
{  
"challenge_type":"Individual",
"description":" ",
"description_fr":null,
"description_lang":{  
  "en":"New Challenge",
  "fr":null
},
"challengeUrl":" ",
"start_date":"01-10-2015",
"end_date":"31-10-2015",
"name":" ",
"name_fr":null,
"name_lang":{  
  "en":"New Challenge ",
  "fr":null
},
"points_cap":0,
"points_goal":0,
"short_description":" ",
"short_description_fr":null,
"short_description_lang":{  
  "en":"New Challenge",
  "fr":null
},
"number_participants":0,
"number_teams":0,
"teams":[  

],
"challenge_id":265,
"activity_exclusion_list":[  

],
"leagueId":1

}

1 个答案:

答案 0 :(得分:0)

在您的挑战路线中,您是否尝试过使用this.store.filter?问题可能是查询函数只返回一个RecordArray,而filter返回一个Live RecordArray,当promise(在这种情况下是成功保存)被解析时,它将更新你的模板和其他所有内容。

model: function() {
    return this.store.filter('challenge', {league_id: this.get('userProfile.league_id')}, function() {
      // We're not actually filtering, so just return true for everything
      return true;
    });
}

我遇到了同样的问题,结果证明这是一个解决方案,希望它有所帮助!

Ember Docs reference