How do I pass back data from a remote window to a chrome extension's background page?

China☆狼群 提交于 2019-11-30 13:01:58

It is basically possible. What you should do is to use the content script as a bridge between your newly created window and your background script. For example:

Your background script:

chrome.runtime.onMessage.addListener(function(message, sender, sendResponse) {
    alert("message received");
});
chrome.windows.create({
    type : 'popup',
    url : "http://yoursite.com/page.html",
    type: "popup"
}, function(newWindow) {

});

Your content script:

document.addEventListener("hello", function(data) {
    chrome.runtime.sendMessage("test");
})

page.html:

<script>
    var go = function() {
        var event = document.createEvent('Event');
        event.initEvent('hello');
        document.dispatchEvent(event);
    }
</script>
<a href="javascript:go();">Click me</a>

So, the idea is to dispatch an event from the page using document object. The content script listens for that event and once occur send a message to the background script where your code is originally.

I believe messaging isn't necessary for what you're doing. (Unless I'm missing something.) I'm experimenting with creating an extension, and needed to create a popup to query the user for some information. At first I used messaging, then I read the following page:

http://developer.chrome.com/extensions/event_pages.html

Include a js in your html page which uses either extension.getBackgroundPage or runtime.getBackgroundPage [use the latter if you're using a non-persistent background page] to get at the background script. It could be as easy invoking a function on your background page like this:

extension.getBackgroundPage().sendDataOrWhateverYouCallIt(data);

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!