It is a long name, but it will self-explanatory so, its worth
Or is it?...
It turns out that Chrome extensions does not have access to the JavaScript on a webpage, even if the extension is a content script. As a result, you can't access variables and content on the page itself.
It's disapointing. Anyway, there is a solution, you have to inject a script tag to the page and then execute whatever you want in this script. You may ask yourself what is the problem? It's ugly as f, that's the problem.
Well, luckily, I've got the solution!
This tiny library allows you to easily execute JavaScript code in a webpage from your Chrome extension.
But how does it work? It is as simple as this:
exec(() => {
console.log('This is the window of the current webpage:', window);
});
Nice, huh? I know!
Anyway, so that's more or less it. Best 500 bytes (unminified) your Chrome extension is going to get.
I just love jsDelivr.
-
Download the script from the this --> URL <--, and put it somewhere in your extension's folder:
-
Go to your manifest file, make sure you have
contentSettings
permission, like this:
"permissions": [
"contentSettings"
]
Under content_scripts
add a js
array and insert the path to the library file as an item.
No worries, here's an example:
Assuming your script is in a folder called js
:
"content_scripts": [
{
"js": [
"js/execute-on-website.min.js",
"./inject.js"
]
}
]
It's as simple as that.
Navigate to your extension's folder, and run the following command: (After making sure you have Node installed)
npm i chrome-extension-execute-on-website
Good, now go to your manifest.json
, make sure you have contentSettings
permission:
"permissions": [
"contentSettings"
]
Under content_scripts
add js
array and add the following path as an item:
node_modules/chrome-extension-execute-on-website/execute-on-website.js
And that should do the job. Here is an example:
"content_scripts": [
{
"js": [
"node_modules/chrome-extension-execute-on-website/execute-on-website.js",
"./inject.js"
]
}
]
Here is an example of a full manifest, with the library included:
{
"name": "My Extension",
"version": "0.0.4",
"manifest_version": 2,
"description": "",
"homepage_url": "http://eliran.net",
"icons": {
"16": "icons/Lightning16.png",
"19": "icons/Lightning19.png",
"48": "icons/Lightning48.png",
"128": "icons/Lightning128.png"
},
"permissions": [
"contentSettings"
],
"content_scripts": [
{
"matches": [
"*://*/*"
],
"js": [
"js/execute-on-website.min.js",
"./inject.js"
]
}
]
}