【问题标题】:Ember JS - Cannot read property 'save' of undefinedEmber JS - 无法读取未定义的属性“保存”
【发布时间】:2017-04-29 15:21:17
【问题描述】:

简而言之,我在路由的模型挂钩中创建了一条记录(“claimant”),但是当我尝试在操作处理程序中获取“claimant”记录时,Ember 说该记录不存在。结果,当我尝试保存“索赔人”时,Ember 告诉我它“无法读取未定义的属性‘保存’。”我猜这是我的初始化程序的问题,但我不知道为什么。

任何帮助将不胜感激。谢谢!

相关代码如下:

models/claimant.js

import attr from 'ember-data/attr';
import DS from 'ember-data';
import { belongsTo } from 'ember-data/relationships';

export default DS.Model.extend({
first_name: attr('string'),
submission: DS.belongsTo('submission', {async: false}),
});

models/submission.js

import DS from 'ember-data';
import { belongsTo } from 'ember-data/relationships';

export default DS.Model.extend({
claimant: belongsTo('claimant', {async: false}), 
});

routes/claimant.js

import Ember from 'ember';

export default Ember.Route.extend({
actions: {
    next: function() {
        let claimant = this.get('claimant');
        claimant.save().then(claimant => {
            this.get('submission').createSubmission({
            claimant: claimant
            });
        });
        this.transitionTo('defendant');
    },
},

model() {
    let claimant = this.get('store').createRecord('claimant', {
        first_name: this.get('first_name'),
        });
    return claimant;
}
});

注意:如果我改用 let claimant = this.get('controller.model');记录正确保存,但是“提交”和“索赔人”之间的 BelongsTo 关系没有正确设置。不知道为什么。

initializers/submission-initializer.js

import Ember from 'ember';
const {isNone, isEmpty, merge} = Ember;

let submissionProxy = Ember.ObjectProxy.extend({
_currentSubmission: null,
_store:null,

content: function() {
    let currentSubmission = this.get('_currentSubmission');

    if (isEmpty(currentSubmission)) {
    currentSubmission = this.createSubmission();
    }
     return currentSubmission;
    }.property('_currentSubmission'),

current: Ember.computed.alias('content'),

createSubmission(data = {}) {

    let newSubmission = this.get('_store').createRecord('submission', data);   
    this.set('_currentSubmission', newSubmission);
    return newSubmission;
},
});

export function initialize(application) {
application.register('submission:proxy', submissionProxy, {singleton: true});
application.inject('submission:proxy', '_store', 'service:store');
application.inject('component', 'submission', 'submission:proxy');
application.inject('route', 'submission', 'submission:proxy');
application.inject('controller', 'submission', 'submission:proxy');
};

export default {
name: 'submission-initializer',
after: ['ember-data'],
initialize: initialize
};

模板/claimant.hbs

<h2 id="title">Welcome to the Claimant Page!</h2>

<form>
<div class="form-group">
  <label for="first_name">First Name</label>
  {{input id="first_name" class="form-control" value=model.first_name}}
</div>

<button class="btn btn-primary" {{action 'next' model}}>Next</button>
</form>

【问题讨论】:

  • 我对 EmberJS 很陌生,但我认为您在 'let claimant = this.get('claimant');' 中定义的变量 'claimant'从字面上看被设置为未定义。因此,您会收到该错误。

标签: ember.js


【解决方案1】:

两件事 - A)在您的操作中使用 this.get('model').save (模型正在返回索赔人,但在您的操作中,您无法访问模型中定义的局部变量 - 即“索赔人” )

B) 在您的模型中,first_name: this.get('first_name') 将不起作用 --> 您可能希望在路由中定义一个变量并将其绑定到 hbs 文件中的输入字段,然后访问该变量模型中的变量。

希望这会有所帮助!

【讨论】:

  • 谢谢@Chhirag Kataria!两个简单的问题:1)我之前尝试使用 this.get('controller.model') 并调用 save。这有效(它将模型保留到后端),但是当我这样做时,“索赔人”和“提交”之间的 BelongsTo 关系没有设置。结果,当我保存“提交模型”时,后端将关系显示为未定义。有什么想法吗? 2)你能澄清你在B)中的意思吗?我不确定这与我当前的代码有何不同。谢谢!
  • @MathewAndrews 是的,this.get('controller.model') 节省了后端,因为您实际上是在访问模型来执行此操作,这等于我在 (A) 中所拥有的。我不确定您所说的关系没有正确设置是什么意思-我查看了您的代码,不知道为什么您有 this.get('submission').createSubmission ... createSubmission 是什么,this.get 是什么('提交')? (B) 谈到你直接访问 this.get('first_name') - 它在哪里定义?
  • 谢谢@Chhirag Kataria 当我说关系没有正确设置时,我的意思是当我将“索赔人”模型和“提交”都保存到后端服务器时,后端告诉我两者没有关系。 BelongsTo 属性显示为 null。知道为什么会这样吗?
  • @MathewAndrews 尝试将索赔人:belongsTo 更改为索赔人:DS.belongsTo
  • @MathewAndrews 也是,我不知道这是否是完整的代码,但您如何设置所有内容似乎存在很多一般性问题 - 正如我之前的评论,有几件事是未定义的。我想说仔细看看并广泛参考文档。
猜你喜欢
  • 1970-01-01
  • 2019-03-25
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多