Puncte:0

Why does my JS file not get loaded?

drapel nl

I am a beginner with Drupal. I want to include a JavaScript file using a custom module.

I created the .libraries.yml file, hello_world.libraries.yml.

hello_world_js:
  js:
    js/basic.js: {}
  dependencies:
    - core/jquery
    - core/drupal
    - core/drupalSettings

The module .info.yml file (hello_worl.info.yml) contains a reference to the library.

name: Hello World
type: module
description: Say Hello World
package: Custom
core: 8.x
libraries:
  - hello_world/hello_world_js

The JavaScript code in the basic.js file is the following one.

(function($,Drupal){
  Drupal.behaviors.addAccessionBehavior = {
    attach: function(context, settings){
      $(".query_button").click(function(){
        console.log("works");
      });
    }
  };
})(JQuery, Drupal);

When I click on a button using the .query_button CSS class, nothing happens and I don't know what the problem is.

leymannx avatar
drapel ne
Trebuie să atașați biblioteca. Acum doar ai declarat-o. https://www.drupal.org/docs/drupal-apis/javascript-api/add-javascript-to-your-theme-or-module#s-attaching-the-file
Francisco Javier Valero Moreno avatar
drapel nl
când am declarat în info.yml, nu este atașat în întregime web?
leymannx avatar
drapel ne
Într-un fișier cu informații despre temă, da. Într-un fișier cu informații despre modul, nr. Modulele nu au cheia `biblioteci:`. L-ați declarat în *.libraries.yml și acum trebuie să îl atașați. Nu puteți atașa biblioteci în fișierele cu informații despre modul.
Francisco Javier Valero Moreno avatar
drapel nl
Văd, trebuie să fac asta $build['#attached']['library'][] = 'hello_world/hello_world_js'; ca exemplu, dar tot nu funcționează
leymannx avatar
drapel ne
Unde ai adăugat exact această linie de cod? [`hello_world_page_attachments`](https://api.drupal.org/api/drupal/core%21lib%21Drupal%21Core%21Render%21theme.api.php/function/hook_page_attachments/8.3.x) în hello_world.module?
Francisco Javier Valero Moreno avatar
drapel nl
Am adăugat acum la hello_world.module, dar acum am o altă eroare cu ajax (?ajax_form=1&_wrapper_format=drupal_ajax: ajax.$form.ajaxSubmit nu este o funcție) și un buton decât nu aveam înainte, așa că voi presupune decât acum se încarcă, dar ceva nu este în regulă, mulțumesc :D Voi încerca să aflu care este eroarea acum
drapel fr
În general, codul tău pare OK. De multe ori, astfel de probleme se datorează fie numelui, fie locației fișierelor dvs. Ați declarat fișierul JavaScript ca „js/basic.js”, ceea ce înseamnă că trebuie să fie localizat într-un subdirector numit „js”, așa că în directorul modulului de nivel superior ar trebui să aveți „hello_world.info.yml” și „hello_world”. module” și directorul „js”, în timp ce în directorul „js” ar trebui să aveți „basic.js”
Francisco Javier Valero Moreno avatar
drapel nl
da, am rezolvat, ca răspunsul de mai jos, am scris JQuery în loc de jQuery și asta îmi dădea eroarea
Puncte:0
drapel de

Dacă te uiți într-o consolă JavaScript, poți obține mai multe informații. Probabil că aveți o eroare în consola dvs. care spune JQuery nu este definit. Asta pentru că ai declarat JQuery dar variabila este jQuery. Deci asta:

})(JQuery, Drupal);

Ar trebui sa fie asta:

})(jQuery, Drupal);

De asemenea, când doriți să testați dacă fișierul dvs. a fost atașat, ar trebui să adăugați o comandă de depanare direct în behaviors.attach(), mai degrabă decât o sub-funcție care necesită un clic (cum ați făcut). Deci, puteți testa dacă scriptul dvs. a fost adăugat astfel:

Drupal.behaviors.addAccessionBehavior = {
  atașați: funcție(context, setări){
    console.log("funcționează");
    $(".query_button").click(function(){
      // Faceți chestii la clic
    });
  }
};

Acest lucru va înregistra ceva la încărcarea paginii, ceea ce vă spune că scriptul s-a încărcat (și conține variabilele necesare).

Francisco Javier Valero Moreno avatar
drapel nl
Da, de fapt, asta a fost cauza erorii pe care am avut-o, vă mulțumesc foarte mult
Jaypan avatar
drapel de
Atunci vă rog să marcați soluția mea ca răspuns corect.

Postează un răspuns

Majoritatea oamenilor nu înțeleg că a pune multe întrebări deblochează învățarea și îmbunătățește legătura interpersonală. În studiile lui Alison, de exemplu, deși oamenii își puteau aminti cu exactitate câte întrebări au fost puse în conversațiile lor, ei nu au intuit legătura dintre întrebări și apreciere. În patru studii, în care participanții au fost implicați în conversații ei înșiși sau au citit transcrieri ale conversațiilor altora, oamenii au avut tendința să nu realizeze că întrebarea ar influența – sau ar fi influențat – nivelul de prietenie dintre conversatori.