Hi, I was trying to make a chrome extension which injects code into a website when a inject button is pressed. I don’t know how to run code on the website, only the popup for my extension. Help is greatly appreciated.
Hi, thanks for your response, I have used this code and I have gotten 0 errors - I’m not sure why nothing has happened; looking into it.
Update: I’ve figured out it’s something to do with the method of getting tabs, I’m trying to find out how I can get the tab id.
https://developer.chrome.com/docs/extensions/reference/api/tabs
(Probably most relevant sublink: https://developer.chrome.com/docs/extensions/reference/api/tabs#messaging )
Thanks, I’m still getting 2 errors from my extension:
Error handling response: TypeError: Error in invocation of scripting.executeScript(scripting.ScriptInjection injection, optional function callback): Error at parameter 'injection': Error at property 'target': Error at property 'tabId': Invalid type: expected integer, found object.
and for my function:
TypeError: Cannot read properties of undefined (reading 'id')
at getCurrentTab
A Tab is an object with a property ‘id’.
Yes, I don’t understand where I have gone wrong I can send my code inside of my background.js file:
async function getCurrentTab() {
let queryOptions = { active: true, lastFocusedWindow: true };
let [tab] = await chrome.tabs.query(queryOptions);
return tab.id;
}
chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
console.log('Message received in background script:', message);
if (message.action === "print") {
console.log('run a', message);
chrome.tabs.query({ active: true, currentWindow: true }, function (tabs) {
var currTab = Number(getCurrentTab());
console.log('run b', message);
chrome.scripting.executeScript({
target: { tabId: currTab },
files: ["do_print.js"],
}).then(() => console.log("script injected"));
});
}
});
Thanks for the help but I fixed it with:
chrome.runtime.onMessage.addListener((message, sender, sendResponse) => {
console.log('Message received in background script:', message);
if (message.action === "print") {
chrome.tabs.query({ active: true }, function (tabs) {
let tab = tabs[0];
chrome.scripting.executeScript(
{
target: { tabId: tab.id },
function: printHello,
},
);
});
}
});