Partage
  • Partager sur Facebook
  • Partager sur Twitter

Appeler des fonctions JS depuis un champ de texte

extension chrome

    21 septembre 2022 à 10:27:46

    je suis entrain de créer ma première extension chrome et j'ai des soucis pour appeler des fonctions JS depuis un champ de texte, mais ça ne marche  pas si vous avez des propositions svp et merci, voici les codes que j'ai pour le moment:
    manifest.json
    ----------------
    {
    "name": "Zero Retard",
    "version": "1.0",
    "manifest_version": 3,
    "description": "Auto fill form GRC",
    "icons": { 
    "16": "icon/icon.png",
    "48": "icon/icon.png",
    "128": "icon/icon.png" 
    },
    "action": {
    "default_popup": "index.html",
    "default_icon": "icon/icon.png"
    },
    "options_page": "options.html",
    "content_scripts": [
    {
    "matches" : [
    "http://*/*",
    "https://*/*"
    ],
    "js": ["jquery-3.6.0.min.js", "injector.js"]
    }
    ],
    "permissions": [
    "clipboardWrite",
    "activeTab",
    "notifications",
    "contextMenus",
    "storage",
    "scripting",
    "tabs"
    ]
    }
    index.html
    -------------
    <!doctype html>
    <html>
      <head>
    <style>
    body {
    min-width: 120px;
    overflow-x: hidden;
    font-family: Arial, sans-serif;
    font-size: 12px;
            }
            input, textarea {
                width: 140px;
            }
            input#save {
                font-weight: bold; width: auto;
            }
        </style>
      </head>
      <body>
    <h1>GRC</h1>
        <center><form>
      <div>
    <label><b>Veuillez saisir un code</b></label>
        <input name="inpt" id="inpt" autocomplete="off"/>
     <p>
    <button id="btn">Enter</button>
    <script src="popup.js"></script>
    </p>
      </div>
    </form></center>
      </body>
    </html>
    popup.js
    ----------
    const button = document.getElementById('btn');
    const input = document.getElementById('inpt');
    button.onclick = async evt => {
      const [tab] = await chrome.tabs.query({ active: true, currentWindow: true });
      await chrome.scripting.executeScript({
        target: { tabId: tab.id },
        files: ['injector.js'],
      });
      await chrome.scripting.executeScript({
        target: { tabId: tab.id },
        func: inPage,
        args: [input.value],
      });
      window.close();
    };
    function inPage(index) {
      functions[index]();
    }
    injector.js
    ------------
    functions = {
     1 : function(){alert(1);},
     2 : function(){alert(2);},
     3 : function(){alert(3);},
     4 : function(){alert(4);},
     5 : function(){alert(5);},
     6 : function(){alert(6);},
    }
    function(f){
      functions[f]();
    }

    -
    Edité par SLAWIMAHDI 21 septembre 2022 à 12:31:03

    • Partager sur Facebook
    • Partager sur Twitter
      21 septembre 2022 à 11:40:23

      Bonjour,

      Le message qui suit est une réponse automatique activée par un membre de l'équipe. Les réponses automatiques leur permettent d'éviter d'avoir à répéter de nombreuses fois la même chose, ce qui leur fait gagner du temps et leur permet de s'occuper des sujets qui méritent plus d'attention.
      Nous sommes néanmoins ouverts et si vous avez une question ou une remarque, n'hésitez pas à contacter la personne en question par Message Privé.

      Pour plus d'informations, nous vous invitons à lire les règles générales du forum

      Merci de colorer votre code à l'aide du bouton Code

      Les forums d'Openclassrooms disposent d'une fonctionnalité permettant de colorer et mettre en forme les codes source afin de les rendre plus lisibles et faciles à manipuler par les intervenants. Pour cela, il faut utiliser le bouton Code de l'éditeur, choisir un des langages proposés et coller votre code dans la zone prévue.

      Merci de modifier votre message d'origine en fonction.

      • Partager sur Facebook
      • Partager sur Twitter

      Pas d'aide concernant le code par MP, le forum est là pour ça :)

      Appeler des fonctions JS depuis un champ de texte

      × Après avoir cliqué sur "Répondre" vous serez invité à vous connecter pour que votre message soit publié.
      × Attention, ce sujet est très ancien. Le déterrer n'est pas forcément approprié. Nous te conseillons de créer un nouveau sujet pour poser ta question.
      • Editeur
      • Markdown