Не специалист по Drupal, но эта запись в блоге предполагает, что начиная с Drupal 6 вам вообще не нужно включать функцию $(document).ready()
в наш код jQuery.
Вместо этого вы можете поместить весь код в функцию, назначенную в качестве свойства Drupal.behaviors
.
В misc/ directory
установки Drupal у нас есть не только файл jquery.js, но у нас также есть drupal.js (и несколько других файлов js, управляющих функциями, специфичными для определенных страниц или функциями администратора, например, upload.js ), который регулирует общее использование jQuery в Drupal.
Он объявляет объект JavaScript Drupal с целью содержать свойства, которые должны быть доступны и использоваться другими js-файлами. Например, свойство Drupal.settings используется для передачи массива настроек модуля в код js для этого модуля. Это можно сделать, просто вызвав drupal_add_js () в вашем php-коде и убедившись, что второй параметр передается как «setting», например:
drupal_add_js(array('mymodule' => $array_of_settings), 'setting');
В вашем js-файле вы можете получить доступ к этим настройкам на Drupal.settings.mymodule. Таким образом, вы расширили объект Drupal.settings свойством mymodule, которое само по себе является объектом, содержащим все ваши настройки.
Другим свойством объекта Drupal является объект поведения, то есть Drupal.behaviors
, и когда мы хотим, чтобы наш модуль добавил новые поведения jQuery, мы просто расширяем этот объект. Весь код jQuery для вашего модуля может быть структурирован так:
Drupal.behaviors.myModuleBehavior = function (context)
{
//do some fancy stuff
};
Но, вы можете задаться вопросом, все, что делает, это объявляет функцию - как она вообще вызывается? Что ж, это все, что присматривается в drupal.js. Он имеет функцию $(document).ready
, которая вызывает функцию Drupal.attachBehaviors
, которая, в свою очередь, циклически перебирает объект Drupal.behaviors
, вызывая каждое из его свойств, причем все они являются функциями, объявленными различными модулями, как указано выше, и передавая документ как контекст .
Причина, по которой вы делаете это таким образом, заключается в том, что если ваш код jQuery выполняет AJAX-вызовы, в результате которых на страницу добавляются новые элементы DOM, вы можете захотеть, чтобы ваше поведение (например, скрытие всех элементов h3 или чего-либо другого) было присоединено к этому новый контент, а также. Но так как он не существовал, когда DOM был загружен и запущен Drupal.attachBehaviors
, к нему не было прикреплено никакого поведения. Однако при вышеописанной настройке все, что вам нужно сделать, это вызвать Drupal.behaviors.myModuleBehavior(newcontext)
, где newcontext
будет новым, AJAX-доставленным контентом, таким образом гарантируя, что поведение не будет привязано ко всему документу во всем снова. Смотрите здесь полный пример того, как использовать этот код