pac*_*ico 6 javascript google-chrome callback google-chrome-extension
我正在编写一个与 gmail api 交互的 chrome 扩展(chrome 45 是我的版本),但在将消息从 background.js 发送到我的内容脚本时遇到问题。异步方面是问题所在。如何获取回调后发送的消息?
//---------in content script---------
chrome.runtime.sendMessage({ messageId: _id }, function (response) {    
    console.log('the respose.messagePayload is: ' + response.messagePayload); 
});
//---------in background script---------
chrome.runtime.onMessage.addListener(function (request, sender, sendResponse) {
    getMessage('me', request.messageId, function (payload) {
        //i want to send my response here
        //this executes and grabs the payload of data from the api, but isn't sending back the message to the content-script
        sendResponse({ messagePayload: payload }); 
    });
    //this synchronous call sends a message to the content-script
    //sendResponse({ messagePayload: "payload" });
    return true;
});
function getMessage(userId, messageId,callback) {
    var request = gapi.client.gmail.users.messages.get({
        'userId': userId,
        'id': messageId
    });
    request.execute(callback);
}
Nik*_*rma -1
您应该sendResponse在回调中发送该函数。
getMessage('me', request.messageId, sendResponse);
然后在getMessage呼叫完成后执行此操作。
function getMessage(userId, messageId, sendResponse) {
    var request = gapi.client.gmail.users.messages.get({
        'userId': userId,
        'id': messageId
    });
    request.execute(function(response) {
        sendResponse({messagePayload: response.payload});
    });
}
另一个可能的解决方案:
tab id从对象中获取sender。getMessage函数,而不是回调函数。getMessage会将有效负载发送回内容脚本。onMessage侦听器,该侦听器将接收您的有效负载,然后对有效负载执行您想要执行的操作。你的代码将是这样的:
//---------in background script---------
chrome.runtime.onMessage.addListener(function (request, sender,sendResponse) {
    getMessage('me', request.messageId, sender.tab.id);
});
function getMessage(userId, messageId, tabId) {
    var request = gapi.client.gmail.users.messages.get({
        'userId': userId,
        'id': messageId
    });
    request.execute(function(response) {
        // Whatever response you want to sent
        // Below URL explains your response object
        // https://developers.google.com/gmail/api/v1/reference/users/messages#resource
        // Assuming you want to send payload
        chrome.tabs.sendMessage(tab.id, {messagePayload: response.payload});
    });
}
//---------in content script---------
chrome.runtime.sendMessage({ messageId: _id });
chrome.runtime.onMessage.addListener(function (request, sender,sendResponse) {
    // Just to verify that the request is from the getMessage callback
    // Because this will listen to all request from your extension
    if (request.messagePayload) {
        console.log('the respose.messagePayload is: ' + request.messagePayload);
    }
});
我希望这有帮助。
| 归档时间: | 
 | 
| 查看次数: | 1034 次 | 
| 最近记录: |