モジュールのJavaScriptを変更するにはどうすればよいですか?


11

「Webform AJAX」モジュールのJavaScriptコードを変更する必要があります。これは、モジュールをハッキングせずに、モジュールの更新時にすべてを失うリスクなしに可能ですか?

回答:


19

モジュールでhook_js_alter()を使用できます。たとえば、このコードは、Drupalが使用するjQueryライブラリを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';
} 

インラインJavaScriptコードでも同じことができます。違いは次のとおりです。

  • の代わりに'misc/jquery.js'、最初のインデックスは数値です
  • $javascript[$index]['data'] JavaScriptコードが含まれます

つまり、最初に置き換えるJavaScriptコードのエントリを見つけ、それを変更する必要があります。この場合、次のコードが機能するはずです。

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;
    }
  }
}

別の方法として、モジュールによって実装されたライブラリを変更する必要がある場合は、hook_library_alter()を実装できます。たとえば、これはjQuery Updateモジュールの最新バージョンによって実装されたコードです。

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';
  }
}

これは、Drupalコアで使用されるJavaScriptコードにも有効です。これらのJavaScriptファイルでは、Systemモジュールがhook_library()を実装しているためです。(system_library()を参照してください。)

hook_js_alter()Drupalコアで使用されるファイルであっても、任意のJavaScriptファイル/コードに使用できます。間hook_js_alter()hook_library_alter()、JavaScriptファイルをライブラリとして公開されている場合には、後者を実施することが好ましいです。

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.