[英]Firefox addon sdk synchronous request
我正在尝试构建一个将在远程网站上实现登录表单的firefox扩展。 基本上,扩展程序将通过单击地址栏附近的扩展程序图标打开一个弹出窗口。 我使用此模块实现的弹出行为
https://github.com/Rob--W/browser-action-jplib
第一次尝试构建javascript登录脚本时,我使用不是main.js中的数据脚本实现了对远程网站的ajax调用。 这个解决方案是错误的,因为从我阅读的内容来看,数据脚本不支持ajax调用,而我需要使用main.js中的request模块来实现。 为此,我在main.js中使用了request模块,并转到下一个代码:
data.js(弹出窗口中使用的数据文件夹中的脚本)
extension.sendMessage(
{
action:"login",
data:{user:user,password:password}
},function(r){
//Handle server response. If ok show post login screen if not show invalid credentials.
});
主要。 JS
var popup = badge.BrowserAction({
default_icon: data.url("icon.png"),
default_popup: data.url("popup.html")
})
popup.onMessage.addListener(function(message, sender, sendResponse) {
if(message.action == 'login'){
sendResponse(login(message.data));
}
});
function login(data ){
var ret;
login = Request({
url: url,
content:data,
onComplete: function (response) {
ret = response.json;
}
});
login.get();
return ret;
}
因为请求是异步的,所以我将空响应发送回data.js。 我查看了请求模块文档,但没有找到解决方案。
是否有人拥有或知道解决此问题的解决方案?
谢谢 !
这实际上非常简单-在获得响应之前不要调用sendResponse
。 您可以将sendResponse
函数作为login
函数的回调传递:
popup.onMessage.addListener(function(message, sender, sendResponse) {
if(message.action == 'login'){
login(message.data, sendResponse);
}
return true;
});
function login(data, callback){
...
onComplete: function(response) {
callback(response.json);
}
...
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.