1

私はSO全体を検索し、Googleドキュメントを読んでいますが、解決策が見つからないようです。

Chrome拡張機能がコンテンツスクリプトonRequest.listenerを挿入しています。コンテンツスクリプトにRequestsを送信するためにを設定したいと思います。これは、私がに使用したスクリプトonRequest.listenerです。問題は、なんらかの理由でこのエラーが発生し続けることです。

エラーメッセージ:

Uncaught TypeError: Cannot ready property 'onRequest' of undefined

contentscript.js line 1;

関連するコードは次のとおりです...

Manifest.json

{
  "name": "Injector Extension",
  "version": "1.0",
  "manifest_version": 1,
  "icons": { "128": "icon.png" },
  "browser_action": {
    "default_icon": "icon.png",
    "default_title": "Injector Extension",
    "default_popup": "popup.html"
  },
  "options_page": "options.html",
  "background": {
    "page": "background.html"
  },
  "permissions": [
    "tabs", 
    "http://*/*",
    "https://*/*",
    "unlimitedStorage"],
  "content_scripts": [{
        "matches": [" (injector specific url) "],
        "js": ["contentscript.js"]
  }],
  "web_accessible_resources": ["js/script.js"] 
}

コンテンツスクリプト

 chrome.extension.onRequest.addListener(function(request, sender, sendResponse) {
  if (request.method == "fromPopup") {

    // Send JSON data back to Popup.
    sendResponse({data: "from Content Script to Popup"});

  } else {
     sendResponse({}); // snub them.
  }
});

現れる

chrome.tabs.getSelected(null, function(tab) {
   chrome.tabs.sendRequest(tab.id, {method: "fromPopup", tabid: tab.id}, function(response) {
      console.log(response.data);
   });
});
4

1 に答える 1

5

chrome.extension.onRequest.addListener拡張コンテキストでのみ機能します。コンテンツ スクリプト内では実行されません。

chrome.extension.sendRequestコンテンツ スクリプト コンテキストで動作する

それに応じて更新すると動作します。

編集:単純なメッセージの受け渡しの例:

拡張スクリプト:

chrome.extension.onRequest.addListener(function(r,s,sr){ 
     if(r==='HELLO') return sr.call(this,'BACK AT YOU');
});

コンテンツ スクリプト:

chrome.extension.sendRequest('HELLO', function(data){ alert(data); });
// will alert "BACK AT YOU"
于 2012-05-16T22:55:36.160 に答える