Maison >interface Web >js tutoriel >Comment transmettre des paramètres aux scripts de contenu injectés dans les extensions Chrome ?
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.
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>
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!