javascript - Ember-data:如果不存在则创建一条记录?

标签 javascript ember.js ember-data ember-local-storage

我有一个计算属性,如果记录不存在,我试图创建一个记录,但在尝试呈现计算属性时不断收到 jQuery.Deferred 异常

这是我目前所拥有的:

deadlineDay: computed(function() {
  const oneWeekFromNow = moment().startOf('day').add(1, 'week');
  const store = this.get('store');

  return store.queryRecord('deadline-day', {
    filter: {
      date: oneWeekFromNow
    }
  }).then(result => {
    if (!result) {
      result = store.createRecord('deadline-day', {
        date: oneWeekFromNow
      });

      result.save();
    }

    return result;
  });
}),

然后在我的模板中,我尝试使用一个简单的助手进行渲染:

{{display-date deadlineDay.date}}

{{display-date}} 助手只调用 return date.format('dddd, MMM Do')

看起来 Ember 正在尝试自己呈现 promise ,而不是等待它解决。

这会导致错误,因为 .format 不是 promise 的方法。

我想这是一个非常常见的用例,但我理解有误。非常感谢您的帮助!

我不确定它是否相关,但我的后备存储是来自 ember-local-storage 的 sessionStorage

最佳答案

我同意 Ember 可能会尝试自己呈现 promise ,而不是等待 promise 解决。不幸的是,我现在无法重现错误。

在 Ember.js 中,通常建议将数据调用放在路由文件中。这将允许您在加载模板文件之前进行查询/保存和所有其他数据收集。您描述的计算属性没有显示依赖键,因此这可能证明将调用移动到您的方案的路由文件是合理的。

通用 route.js 示例:

import Ember from 'ember';

export default Ember.Route.extend({
  async model() {
    let record;
    record = await this.store.queryRecord('record', { queryParams });

    if (!record) {
        record = this.store.createRecord('record', { properties });
    }

    return record.save();
  },

});

但是,如果计算属性中的 promise 有用,Ember Igniter 的作者可能会提供一些额外的有用指导,这可能是值得的。 The Guide to Promises in Computed Properties

关于javascript - Ember-data:如果不存在则创建一条记录?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47963838/

相关文章:

javascript - snap.svg 库中的克隆如何工作?

javascript - 如何将 PHP Instagram 签名与 AJAX 结合使用?

node.js - PhantomJS 已崩溃 - 致命 Windows 异常,代码 0xc0000005

ember.js - 如何将任意模板变量传递到 Handlebars 助手中?

ruby-on-rails - 使用 Ember.js & Ember-data & Rails 创建记录并处理记录列表

javascript - 在正则表达式字符括号中包括连字符?

javascript - 在输入字段中自动递增 HTML 表单 ID

Ember.js 路由、导出和动画

javascript - 加载路线时 ember-data 错误 : TypeError {}

javascript - EmberJS - 在模板填充数据之前 promise 未解决