我收到一个 JS 错误,因为我的$(function () {...})
处理程序似乎在加载必备插件脚本之前被触发。仅在 IE 中发生(在 IE7 中测试)。
我有一些<head>
看起来像这样的 HTML:
<script type="text/javascript" src="../resources/org.wicketstuff.jwicket.JQuery/jquery-1.4.2-special.js"></script>
...
<script type="text/javascript" id="noConflict"><!--/*--><![CDATA[/*><!--*/
jQuery.noConflict();
/*-->]]>*/</script>
...
<script type="text/javascript" src="../resources/com.csc.aims.wicket.components.collapsiblefieldset.CollapsibleFieldsetBehavior/jquery.collapsiblefieldset.js"></script>
<link rel="stylesheet" type="text/css" href="../resources/com.csc.aims.wicket.components.collapsiblefieldset.CollapsibleFieldsetBehavior/jquery.collapsiblefieldset.css" />
<script type="text/javascript">
jQuery(function(){
jQuery('#collapse119').collapse({"iconClosedUrl":"../resources/img/white_plus","iconOpenUrl":"../resources/img/white_minus"});
});
</script>
所以请注意,根据 HTML 代码,顺序如下:
- jquery-1.4.2-special.js
- jQuery.noConflict() 调用
- jquery.collapsiblefieldset.js //定义 $.fn.collapse
- jQuery('#collapse119').collapse(...) 被调用
当这段代码在 FF 中运行时,一切正常。当我在 IE7(或 IE8 w/Compat。查看:IE7 标准模式)中测试它时,我收到一个 javascript 错误。调试器告诉我 jQuery.fn.collapse 是未定义的。
使用 IE8 开发人员工具,我尝试查看 jquery.collapsiblefieldset.js。我在列表中看到了该脚本,但该工具告诉我无法设置断点,因为该脚本未加载。
为什么 collapsiblefieldset.js 在我的 $() 就绪处理程序运行之前没有被加载?任何见解将不胜感激!谢谢。