I'm trying to get my Chrome Extension to inject some javascript with content_scripts
, using this previous answer as a reference.
manifest.json
"name": "My Chrome Extension",
"version": "1.0",
"manifest_version": 2,
"content_scripts": [{
"matches": ["http://pagetoinject/script/into/*"],
"js": ["contentscript.js"]
}]
contenscript.js:
var s = document.createElement('script');
s.src = chrome.extension.getURL("script.js");
(document.head||document.documentElement).appendChild(s);
s.parentNode.removeChild(s);
( also tried this method with no success. )
var s = document.createElement('script');
s.src = chrome.extension.getURL("script.js");
s.onload = function() {
this.parentNode.removeChild(this);
};
(document.head||document.documentElement).appendChild(s);
I keep getting this javascript error. Here's a screenshot.
GET chrome-extension://invalid/
(anonymous function)
In addition to the answers above I notice that in your
contentscript.js
you are just adding another script i.escript.js
Why don't you directly addscript.js
through content_scripts inmanifest.json
."manifest_version": 2
is specified. This automatically activates a stricter mode, in which all extension's files are not available to web pages by default.<script>
element is immediately removed after injection (the script file does not have a chance to load).As a result of 1., the following error shows up in the console:
To fix the problem, add
script.js
to the whitelist,"web_accessible_resources"
in yourmanifest file
:The problem here is that you are using
manifest_version : 2
. If you make thatmanifest-version: 1
you'll not have any problems. Version 2 restricts many such features to improve security. Refer Google Content Security Policy for more details on the restrictions imposed in manifest version 2. I could not find your specific case mentioned in the CSP but when I changed the manifest version to 1 and executed your code it is working fine.