javascript - 从服务访问 Ember-cli 模型类

标签 javascript ember.js

我正在尝试在 Ember-cli 项目中定义一个 Person 类,然后我可以从服务中调用该类。我有一个基本服务,可以在各种输入更改时更新,但我根本无法引用 Person 类。这是我目前拥有的:

# app/models/person.js 

import Ember from "ember";

var Person = Ember.Object.extend({
  helloWorld: function() {
    alert("Hi, my name is " + this.get('name'));
  }
});

export default Person; 

在我的路由器中:

# app/router.js

import Ember from 'ember';
import config from './config/environment';
import Person from './models/person';

var Router = Ember.Router.extend({
  location: config.locationType,
  model: function() {
    return Person.create({
      name: "Tom Dale"
    });
  }
});

我很确定它正确引用了“导入人员”,因为如果错误,我会看到有关找不到文件的错误。

然后在我拥有的服务中:

# /app/services/calculator.js

import Ember from 'ember';

export default Ember.Service.extend({

  init: function () {

    // this gives "Person is not defined"
    const person = new Person();

    // this gives "Person is not defined"
    const person = Person.create({ name: "Tom Jones" });

    // this gives "store not defined" 
    const person = this.store.createRecord('person', { name: "Tom Jones" });

  },
});

任何有关如何从服务访问 Person 类的指示将不胜感激。谢谢!

最佳答案

我会尽力解决我认为存在的一些误解。

首先,您有一个 Person 类,但它不是 DS.Model,因此您将无法通过 Ember Data 使用它(this.store).

您的router.js 文件是您定义路由的位置,as shown in the guides 。您似乎将其与如何 specify a route's model 混淆了?请密切注意代码示例中的文件路径。

至于服务,Person 未定义,因为与 router.js 代码不同,您没有将 Person 导入到模块中。导入是按模块进行的,因此您还需要在服务中 import Person from './models/person'; 。检查jsmodules.io了解更多信息。
Ember Data 的存储仅注入(inject)到 RouteController 中,这就是 this.storeService 中未定义的原因。如果您想访问商店,请执行以下操作:

export default Ember.Service.extend({
  store: Ember.inject.service(),

  init() {
    const person = this.get('store').createRecord('person', { name: "Tom Jones" });
  }
});

请注意,以上不应该工作,因为您发布的 Person 代码不是 DS.Model

关于javascript - 从服务访问 Ember-cli 模型类,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33733664/

相关文章:

javascript - 按多个前缀对数组进行排序

javascript - 带条件的箭头函数对象迭代

javascript - 中止 ext js 网格存储 ajax 调用

ember.js - 如何知道 Controller 是否实现了mixin

ember.js - Ember.View - 如何以正确的方式将另一个 Ember.View 附加到 jQuery HTML 元素?

javascript - 首次尝试 Bootstrap 模式后,计数器值无法正常工作

javascript - 在 .js 文件中使用外部 javascript 文件

ember.js - 具有动态分段的资源并在嵌套路由中检索模型

javascript - Ember 测试访问 promise 不起作用

ember.js - ember-simple-auth:有什么方法可以从路由器中获取 session ?