Maison >interface Web >js tutoriel >Comment transmettre des paramètres aux scripts de contenu injectés dans les extensions Chrome ?

Comment transmettre des paramètres aux scripts de contenu injectés dans les extensions Chrome ?

Barbara Streisand
Barbara Streisandoriginal
2024-10-27 16:22:01352parcourir

How do I pass parameters to injected content scripts in Chrome extensions?

Passer des paramètres aux scripts de contenu injectés

Lors de l'injection d'un script de contenu à l'aide de chrome.tabs.executeScript(), il peut être nécessaire de transmettre des paramètres au script. Cependant, il est crucial de préciser que « transmettre un paramètre à un fichier » n'est pas un concept applicable.

Au lieu de cela, il existe deux options à considérer : définir les paramètres avant ou après l'exécution du script.

Définir les paramètres avant l'exécution

Vous pouvez injecter un script de contenu avec des paramètres prédéfinis en imbriquant les appels chrome.tabs.executeScript :

<code class="javascript">chrome.tabs.executeScript(tab.id, {
    code: 'var config = 1;'
}, function() {
    chrome.tabs.executeScript(tab.id, {file: 'content.js'});
});</code>

Pour les paramètres complexes, utilisez JSON.stringify :

<code class="javascript">var config = {somebigobject: 'complicated value'};
chrome.tabs.executeScript(tab.id, {
    code: 'var config = ' + JSON.stringify(config)
}, function() {
    chrome.tabs.executeScript(tab.id, {file: 'content.js'});
});</code>

Dans content.js :

<code class="javascript">// content.js
alert('Example:' + config);</code>

Définir les paramètres après l'exécution

Les paramètres peuvent également être définis après l'exécution du script à l'aide du passage de messages :

<code class="javascript">chrome.tabs.executeScript(tab.id, {file: 'content.js'}, function() {
    chrome.tabs.sendMessage(tab.id, 'whatever value; String, object, whatever');
});</code>

Dans content.js :

<code class="javascript">chrome.runtime.onMessage.addListener(function(message, sender, sendResponse) {
    // Handle message.
    // In this example, message === 'whatever value; String, object, whatever'
});</code>

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn