- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我调整了 RESTAdapter 中的 ajax 调用以从 vert.x 总线桥接器检索数据。但是,我在处理请求的成功部分检索 promise 时遇到问题。
我想问题出在 Ember 期望的数据结构形式上。这是我的适配器的代码:
var VertxAdapter = DS.RESTAdapter.extend({
protocol: 'http',
host: 'localhost',
port: '4200',
addressMapping: {
"GET localhost/mindMaps": "mindMaps.list"
},
pendingRequests: [],
vertx: function() {
var adapter = this;
if (typeof adapter._vertx === 'undefined') {
adapter._vertx = new vertx.EventBus(adapter.protocol + '://' + adapter.host + ':' + adapter.port + '/eventbus');
console.log('initialize vertx');
adapter._vertx.onopen = function() {
// TODO: register for messages send from server to this client
adapter.processPendingRequests.apply(adapter);
};
}
return adapter._vertx;
},
ajax: function(url, type, params) {
console.log(url, type, params);
var adapter = this;
var messageAddress = adapter.addressMapping[type + " " + url];
return new Ember.RSVP.Promise(function(resolve, reject) {
var success = function(json) {
Ember.run(null, resolve, json);
};
var error = function(json) {
Ember.run(null, reject, json);
};
if(adapter.vertx().readyState === vertx.EventBus.OPEN) {
console.log('ready state');
adapter.processRequest(messageAddress, params, success, error);
} else {
var pendingReq = {
address: messageAddress,
params: params,
success: success,
error: error
};
console.log('push pending req');
adapter.pendingRequests.push(pendingReq);
}
});
},
processPendingRequests: function() {
console.log('processPendingRequests');
var adapter = this;
adapter.pendingRequests.forEach(function(req){
console.log(req);
adapter.processRequest(req.address, req.params, req.success, req.error);
});
},
processRequest: function(address, params, success, error) {
console.log(address, params, success, error);
var adapter = this;
adapter.vertx().send(address, params, function(json){
//TODO: implement
//console.log(arguments);
console.log(JSON.stringify(json));
success(json);
// error(json);
});
adapter.pendingRequests = [];
}
});
export default VertxAdapter.extend({
port: '8080'
});
这是服务器:
var eventBus = require("vertx/event_bus");
var mindMaps = {};
var extend = function(obj, props) {
for (var prop in props) {
if (props.hasOwnProperty(prop)) {
obj[prop] = props[prop];
}
}
return obj;
};
eventBus.registerHandler("mindMaps.list", function(args, responder) {
responder(
{
"data": Object.keys(mindMaps).map(function(key) {
return extend(
{
"type": "mindMaps"
},
mindMaps[key]
);
})
});
});
eventBus.registerHandler("mindMaps.save", function(mindMap, responder) {
if (!mindMap.id) {
mindMap.id = Math.floor((Math.random() * 100) + 1);
}
mindMaps[mindMap.id] = mindMap;
responder({
"data": mindMap
});
});
eventBus.registerHandler("mindMaps.delete", function(args, responder) {
delete mindMaps[args.id];
responder({});
});
这是控制台输出:
{"data":[{"type":"mindMaps","name":"One","id":59},{"type":"mindMaps","name":"Two","id":99},{"type":"mindMaps","name":"Three","id":55}]}
WARNING: Encountered "data" in payload, but no model was found for model name "datum" (resolved model name using mind-maps@serializer:-rest:.typeForRoot("data"))
Error while processing route: mind-maps Assertion Failed: The response from a findAll must be an Array, not undefined Error: Assertion Failed: The response from a findAll must be an Array, not undefined
我想我没有以 Ember 期望的形式从服务器返回数据。
想法?
BR,米兰
最佳答案
除非您还想创建自己的序列化程序,否则您的 JSON 需要采用特定格式。您可以看到记录的格式 here .
如果您无法修改服务器以返回该 JSON 格式,则需要编写自己的 Serializer , 并将您的数据转换为列出的格式 here .
如果这听起来有点过分,那是因为它确实如此。我认为 Ember-Data 的适配器和序列化器是它的头号问题。不幸的是,没有很多简单的方法可以做您想做的事。
关于javascript - EmberJS : Resolve promise in the success of processing request,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29097653/
我使用 resolver() 作为 socket() 的替代方法,因为我发现当多个连接建立到不同的 IP 时,它最终会停止工作。 无论如何它会向我返回一个警告,我应该使用 dns.resolver.R
我有这个代码: var promise1 = new Promise(function(resolve, reject) { setTimeout(() => { console
我仍在学习 PHP,我认为我不是母语人士,这并不难理解。 此时,看了一大堆文档,跳入了深水区,于是打开Laravel源文件,一个接一个地看,试图更好地理解MVC的整个实现,包括路由、中间件如何组合成一
public JsonResult GetEvents(double start, double end) { var userName = Session["UserName"] as st
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
我写了下面的代码: function readFile(path) { return new Promise(function(resolve, reject){ if(!fs
我正在使用 bluebird,我看到了两种将同步函数解析为 Promise 的方法,但我不明白这两种方法之间的区别。看起来堆栈跟踪有点不同,所以它们不仅仅是一个别名,对吧? 那么首选的方式是什么? 方
在某处读过这个例子: return new Promise( (resolve, reject) => { fs.readFile(file, (err, data) => { if (e
我刚开始学习 React,我一直在尝试让我的 React 应用程序连接到我的数据库 var mysql = require('mysql'); var con = mysql.createConnec
我需要从 $http 调用中返回一个 promise 中的自定义响应,以便我可以链接更多调用。我有两个可用的实现。有人可以解释两者之间的区别,并争论其中一个更好吗? 在 fooService.js 实
免责声明:这里实际上提出了两个问题,但我觉得它们密切相关。 我正在尝试将 promise 对象传递给指令,并且我想在 promise 解析后立即在指令中运行一些初始化代码。 在我的 Controlle
我正在尝试创建类似于 this code 的东西在 boost.asio 示例中找到。 套接字.h: class some_class { private: ... boost
正如我们所知,Promise 构造函数采用一个执行函数,该函数具有两个参数,我们使用它们来生成成功案例或失败案例。今天我在编程,我被卡住了,但后来我解决了这个问题,但我发现了一件事需要理解。 有什么区
我认为 Promise.resolve 和 new Promise(resolve) 可以互换。 考虑一下: A. new RSVP.Promise(function (resolve, reject
我下载了一个 Java 项目,我想研究并从中学习一些东西。当我在另一台计算机上下载它时效果很好,但是当我在我的计算机上尝试时,几乎每个声明和导入都会给出错误消息“* cannot be resolve
我昨天看到了一些有趣的编译器行为,我想我明白为什么会这样,但我想确定一下。所以,我不会写我的推理,只写事实。 请注意,我使用 vector 而不是 string 并不是错字。我是故意这样做的,这样编译
我正在尝试运行 Ember 测试,它给出了这个错误,提示无法找到从 `AppName/resolver 导入的模块 ember-resolver。 我不确定是什么原因造成的。我正在使用 Ember-c
Code#1 和 Code#2 的区别在于:Code#1 使用 resolve(p) 而 Code#2 使用 p.then(()=>resolve()) 。我希望输出序列是不变的,但它们会生成不同的序
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
IntelliJ IDEA 无法解析内置 JVM 类型和方法的常见原因有哪些?例如,当我将鼠标悬停在 String 上时,工具提示显示“无法解析符号“String””。就好像 IntelliJ 不知道
我是一名优秀的程序员,十分优秀!