我想在 drupal 站点中执行 jQuery $(document).ready()。虽然我知道我可以把它贴在索引页上,但这真的很混乱而且很糟糕。
我想知道放置它的正确位置在哪里,它还需要特定于主题,因为我不希望所有主题都使用它。
在此先感谢您的帮助。
甜蜜的成功,谢谢你们的帮助,我对这个问题有最后的修改。现在我已经到了这一步,我需要执行 jQuery 代码来更新文档,我可以使用上下文来修改文档吗?
不是 Drupal 专家,但这篇博客文章表明,从 Drupal 6 开始,您根本不需要$(document).ready()
在我们的 jQuery 代码中包含该函数。
相反,您可以将所有代码放在您指定为Drupal.behaviors
.
在
misc/ directory
Drupal 安装中,我们不仅有 jquery.js 文件,而且还有 drupal.js(以及其他几个 js 文件,控制特定于某些页面或管理功能的功能,例如 upload.js),它管理着一般在 Drupal 中使用 jQuery。它声明 Drupal JavaScript 对象的目的是为了包含其他 js 文件需要访问和使用的属性。例如,Drupal.settings 属性用于将一组模块设置传递给该模块的 js 代码。您只需在 php 代码中调用 drupal_add_js() 并确保第二个参数作为“设置”传入,即可完成此操作,例如:
drupal_add_js(array('mymodule' => $array_of_settings), 'setting');
然后,在您的 js 文件中,您可以在 Drupal.settings.mymodule 中访问这些设置。因此,您使用 mymodule 属性扩展了 Drupal.settings 对象,该属性本身就是一个包含所有设置的对象。
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 交付的内容将在哪里,从而确保行为不会再次附加到整个文档。有关如何使用此代码的完整示例,请参见此处
VonC 充分回答了问题的“如何”部分,因此我将重点关注“在哪里”部分。
如果脚本是特定于主题的,那么放置脚本文件的自然位置就是您的主题。问题是当 Drupal 进入主题时,$scripts
变量已经被“渲染”(用 Drupal 的说法)成 HTML。要在主题层中添加脚本,您需要添加脚本并重建$scripts
变量。
假设您使用的是 Drupal 6,这将进入您的theme_preprocess_page()
函数:
drupal_add_js(drupal_get_path('theme', 'theme_name') .'/example.js', 'theme');
$variables['scripts'] = drupal_get_js();
只需更改第二个参数drupal_get_path()
以反映主题的名称,然后将脚本文件的名称从更改example.js
为您为脚本命名的任何名称。