Chrome擴(kuò)展開發(fā)數(shù)據(jù)通信問題

應(yīng)用場景:網(wǎng)站嵌入 content_main.js文件 需要與background.js相互通信回調(diào)

//content_main.js
chrome.runtime.sendMessage({addurl:_url,adddata:data,msg:"contentRequest"}, function(response) {
                if(response.status){
                                        ...
                }else{
                    ...
                }
            });
//background.js
chrome.runtime.onMessage.addListener(function(request, sender, sendResponse) {
    if (request.msg=="contentRequest"){
              //ajax settimeout 等一系列異步操作時(shí)發(fā)現(xiàn)content_main response接不到回調(diào)值 undefined
              ajax({
                type:'post',
                // contentType: 'application/x-www-form-urlencoded',
                contentType: 'application/json; charset=utf-8',
                url:request.addurl,
                // data:{'documents':bibliographic_data},
                data:request.adddata,
                success:function(w){
                    if(w.code==200){
                        sendResponse({status:1,msg:"保存成功!"});
                    }else{
                        sendResponse({status:0,msg:"保存失敗,錯(cuò)誤代碼1001"});
                    } 
                    return true;
                },
                error: function(xhr,info,e,){
                    sendResponse({status:0,msg:"保存失敗,錯(cuò)誤代碼1002"});           
                },
            })
                return true;//  原因在此   完美解決
        }
});

注:使用嵌入式開發(fā)有個(gè)弊端即在https網(wǎng)站嵌入發(fā)異步請求即在content_main中發(fā)后臺請求會(huì)若服務(wù)為http服務(wù)會(huì)發(fā)生請求被拒絕問題,上述案例也完美的解決該問題,僅供參考具體以實(shí)際開發(fā)情況為主。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 179,145評論 25 708
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,612評論 19 139
  • chrome擴(kuò)展開發(fā)入門教程 最近在開發(fā)chrome插件,看到一篇非常適合入門的教程,特記錄一下 注:轉(zhuǎn)載 本文首...
    謝大見閱讀 6,562評論 1 25
  • 盂蘭解倒懸,普渡眾幽魂。 水燈明道路,共佑世上人。
    心憫居士閱讀 256評論 0 3
  • 在知識匱乏的時(shí)代、非終身學(xué)習(xí)的年代,學(xué)肯定比不學(xué)好。 在今天知識爆炸、終身學(xué)習(xí)的時(shí)代,要比的不是學(xué)不學(xué),而是認(rèn)知效...
    霍霍小哥閱讀 684評論 0 10

友情鏈接更多精彩內(nèi)容