background - क्रोम एक्सटेंशन: पृष्ठभूमि से सामग्री स्क्रिप्ट भेजने के लिए मैसेज काम नहीं करता है



google-chrome-extension sendmessage (1)

आपके पृष्ठभूमि पृष्ठ में आपको कॉल करना चाहिए

chrome.tabs.query({active: true, currentWindow: true}, function(tabs){
    chrome.tabs.sendMessage(tabs[0].id, {action: "open_dialog_box"}, function(response) {});  
});

वर्तमान में chrome.extension.sendMessage का उपयोग करने के बजाय।

chrome.tabs संस्करण सामग्री स्क्रिप्ट पर संदेश भेजता है, जबकि chrome.extension फ़ंक्शन सभी अन्य एक्सटेंशन घटकों को संदेश भेजता है।

मुझे पता है कि अलग-अलग तरीकों से प्रश्न बार-बार पूछे गए हैं, लेकिन मैंने सभी उत्तरों से गुज़रने की कोशिश की (उम्मीद है कि मैंने किसी को भी याद नहीं किया) और उनमें से कोई भी मेरे लिए काम नहीं करता था।

मेरा एक्सटेंशन का कोड यहां दिया गया है:

प्रकट:

{
"name": "test",
"version": "1.1",
"background": 
{ 
    "scripts": ["contextMenus.js"]
},

"permissions": ["tabs", "<all_urls>", "contextMenus"],

"content_scripts" : [
    {
        "matches" : [ "http://*/*" ],
        "js": ["jquery-1.8.3.js", "jquery-ui.js"],
        "css": [ "jquery-ui.css" ],
        "js": ["openDialog.js"]
    }
],

"manifest_version": 2
}

contextMenus.js

function onClickHandler(info, tab) {
    if (info.menuItemId == "line1"){

      alert("You have selected: " + info.selectionText);

      chrome.extension.sendMessage({action:'open_dialog_box'}, function(){});

      alert("Req sent?");

    }
}

chrome.contextMenus.onClicked.addListener(onClickHandler);

chrome.runtime.onInstalled.addListener(function() {

  chrome.contextMenus.create({"id": "line1", "type": "normal", "title": "I'm line 1",     "contexts":["selection"]});

});

openDialog.js

chrome.extension.onMessage.addListener(function(msg, sender, sendResponse) {

  if (msg.action == 'open_dialog_box') {
    alert("Message recieved!");
  }
});

पृष्ठभूमि पृष्ठ के दो अलर्ट काम करते हैं, जबकि content_script में से कोई एक नहीं है।

कंसोल लॉग का संदेश: पोर्ट त्रुटि: कनेक्शन स्थापित नहीं कर सका। अंत प्राप्त करना मौजूद नहीं है।

मेरी गलती कहां है?