Come posso modificare il JavaScript di un modulo?


11

Devo modificare il codice JavaScript del modulo "Webform AJAX". È possibile senza hackerare il modulo e rischiare di perdere tutto con gli aggiornamenti del modulo?

Risposte:


19

È possibile utilizzare hook_js_alter () in un modulo. Ad esempio, questo codice sostituisce la libreria jQuery utilizzata da Drupal con il file presente nella directory jquery_update.

function jquery_update_js_alter(&$javascript) {
  // Swap out jQuery to use an updated version of the library.
  $javascript['misc/jquery.js']['data'] = drupal_get_path('module', 'jquery_update') . '/jquery.js';
} 

Lo stesso può essere fatto per il codice JavaScript incorporato. Le differenze sono:

  • Invece di 'misc/jquery.js', il primo indice è un numero
  • $javascript[$index]['data'] conterrà il codice JavaScript

Ciò significa che prima devi trovare la voce per il codice JavaScript da sostituire, quindi modificarla. Il seguente codice dovrebbe funzionare in questo caso.

function mymodule_js_alter(&$javascript) {
  $old_code = 'The code to alter';
  $new_code = 'The new code';

  foreach ($javascript as $index => $info) {
    if (is_numeric($index) && $info['data'] == $old_code) {
      $javascript[$index]['data'] = $new_code;
      break;
    }
  }
}

In alternativa, se è necessario modificare la libreria implementata da un modulo, è possibile implementare hook_library_alter () . Ad esempio, questo è il codice implementato dall'ultima versione del modulo di aggiornamento jQuery .

function jquery_update_library_alter(&$javascript, $module) {

  // We are updating just the system module. For all other cases we return.
  if ($module != 'system') {
    return;
  }

  $path = drupal_get_path('module', 'jquery_update');

  // Make sure we inject either the minified or uncompressed version as desired.
  $min = variable_get('jquery_update_compression_type', 'min') == 'none' ? '' : '.min';
  $cdn = variable_get('jquery_update_jquery_cdn', 'none');

  // Replace jQuery with the latest version.
  $version = variable_get('jquery_update_jquery_version', '1.5');
  jquery_update_jquery_replace($javascript, $cdn, $path, $min, $version);

  // Replace jQuery UI with CDN or local files. If from a CDN include all of jQuery UI.
  jquery_update_jqueryui_replace($javascript, $cdn, $path, $min);

  // Replace the jQuery Cookie plugin.
  $javascript['cookie']['js']['misc/jquery.cookie.js']['data'] = $path . '/replace/ui/external/jquery.cookie.js';
  // Noting the version based on git commit as no version number is available.
  $javascript['cookie']['version'] = '67fb34f6a866c40d0570';

  // Replace jQuery Form plugin.
  $javascript['jquery.form']['js']['misc/jquery.form.js']['data'] = $path . '/replace/misc/jquery.form' . $min . '.js';
  $javascript['jquery.form']['version'] = '2.69';

  // Replace files for jQuery 1.7 and up
  if (version_compare($version, '1.7', '>=')) {
    $javascript['drupal.states']['js']['misc/states.js']['data'] = $path . '/replace/misc/1.7/states.js';
  }
}

Questo vale anche per il codice JavaScript utilizzato dal core Drupal, poiché per quei file JavaScript il modulo System implementa hook_library () . (Vedi system_library () .)

hook_js_alter()può essere utilizzato per qualsiasi file / codice JavaScript, anche per i file utilizzati da Drupal core. Tra hook_js_alter()e hook_library_alter(), è preferibile implementare quest'ultimo, quando i file JavaScript sono esposti come libreria.

Utilizzando il nostro sito, riconosci di aver letto e compreso le nostre Informativa sui cookie e Informativa sulla privacy.
Licensed under cc by-sa 3.0 with attribution required.