ember.js - 使用 RESTAdapter 自定义后请求

标签 ember.js ember-data ember-cli

我的模型通过 Ember 的默认 RESTAdapter 与服务器配合使用。

我刚刚在我的服务器上创建了一个自定义端点 /mail,如果提供了名称、有效的电子邮件地址和文本,它就会发送电子邮件。

如何让 Ember 发送自定义后期请求?完全没有 Ember.ajax 是否可能?

最佳答案

就我个人而言,我不会使用 Ember-Data 来处理这种情况;我通常只使用 Ember-Data 来处理我的持久模型。如果您尝试使用 Ember-Data 进行其他 AJAX 调用,它只会变得一团糟。请记住,Ember-Data 的工作是管理您的持久数据,而它可以执行此操作的一种方法是使用 AJAX 调用。这并不意味着任何需要 AJAX 调用的事情都应该使用 Ember-Data 处理。

我也遇到了同样的问题,我编写了一个实用程序模块,该模块具有适用于我所有非模型 AJAX 内容的功能。这使得更换测试变得非常容易。这是一个小例子:

// utils/ajax.js

export function sendHelpEmail(comment) {
    return new Promise((resolve, reject) => {
        $.ajax({
            type: 'POST',
            url: '/api/contact_us',
            contentType: 'application/json',
            data: JSON.stringify({ comment }),
            processData: false,
            statusCode: {
                200: () => Em.run(null, resolve),
                500: () => Em.run(null, reject)
            }
        });
    });
}

然后,我可以在我的 Controller 中执行类似的操作:

import { sendHelpEmail} from '../utils/ajax.js';

export default Em.Controller.extend({
    actions: {
        sendEmail() {
            sendHelpEmail(this.get('comment'));
        }
    }
});

关于ember.js - 使用 RESTAdapter 自定义后请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28705381/

相关文章:

javascript - 为什么我的对象被添加到两个集合中?

javascript - Ember.js 过渡渲染错误或错误的路由

javascript - emberJS JSONAPI 适配器发送 OPTION 而不是 GET 请求

ember.js - 如何在 ember 2.x 中通过 Controller 操作以编程方式添加组件

javascript - ember 组件递增/递减值

javascript - 带有外部 Handlebars 模板的 Ember.js

ember.js - 您可以预加载相关数据,以便将您的关系缓存在 ember-data 中吗?

javascript - Ember AppKit 和使用 ember 数据的嵌入对象

ember.js - Ember cli -TypeError : undefined is not a function after running ember server

ember.js - Ember : Re-render a route's template when the model changes