每次加载页面时,Ember加载变量

时间:2018-08-11 08:13:08

标签: ember.js handlebars.js ember-data ember-3

我希望在路由器或控制器中使用一个名为“ name”的变量,该变量将在hbs模板中使用。现在,我正在这样做。但是,如果我向后浏览并再次单击指向当前页面的链接,则不会加载get()。它只会在第一次加载,如果我刷新页面。因此,我每次点击页面时,表单中的name值都不会重新加载。

      #controller
      name: computed('model.name', {
        get() {
          return this.get('model.name');
        }
      })



      #.hbs
      {{input type = "text" value=name }}
      <button {{action 'update' model.id }}>Update Post</button> 


        #routefile
      import Route from '@ember/routing/route';
      import EmberObject, { computed } from '@ember/object';
      export default Route.extend({
      model(params) {
       return this.get('store').findRecord('post',params.post_id );
      }
      });

1 个答案:

答案 0 :(得分:1)

您需要添加一个set方法,否则您声明的计算属性将被输入值覆盖(通过{{input}}助手)。

  name: computed('model.name', {
    get() {
      return this.get('model.name');
    },
    set(key, value) {
      return value;
    }
  })