mootools和jquery冲突 - noconflict不适合我

时间:2013-11-30 01:58:05

标签: javascript jquery

我正在向使用mootools的现有网站添加菜单,我的菜单需要jquery库才能运行。我只能控制添加jquery js文件和脚本,mootools必须留在头顶,我的必须在它下面。我尝试在文档就绪功能之前添加jQuery.noConflict();,但无法解决。如果我删除mootools js文件,菜单功能完美。

<script type="text/javascript" src="http://www16.myfantasyleague.com/mootools-core-1.3.1-full-compat-yc.js"></script>


<script type="text/javascript" src="/js/jquery_1.8.2.js"></script>


    <script id="footerScriptsReady" type="text/javascript">
     jQuery.noConflict();
             (function($){

             $('#headerTvRotator').innerfade({ animationtype: 'fade', speed: 250, timeout: 10000, type: 'sequence', containerheight: '40px' }); 
                var saag = CBSi.app.SAAG.init({
                'categories':
                    {
                        "tab1":{
                                "scoreboard_url":"#url-here",
                                "ord":0,
                                "menu_subtitle":"<a2>For<BR CLEAR=LEFT>Commish</a>",
                                "default":0,
                                "content_url":"div_forcommissioners",
                                "menu_title":"",
                                "league_abbr":"tabname",
                                "scoreboard_subtitle":"Live<BR CLEAR=LEFT>Scores"
                            },
                        "tab2":{   
                                "scoreboard_url":"#url-here",
                                "ord":2,
                                "menu_subtitle":"<a2>For<BR CLEAR=LEFT>Owners</a>",
                                "default":0,
                                "content_url":"div_forowners",
                                "menu_title":"",
                                "league_abbr":"tabname",
                                "scoreboard_subtitle":"Live<BR CLEAR=LEFT>Scores"
                            },
                        "tab3":{
                                "scoreboard_url":"#url-here",
                                "ord":3,
                                "menu_subtitle":"<a1>REPORTS</a>",
                                "default":0,
                                "content_url":"div_reports",
                                "menu_title":"",
                                "league_abbr":"tabname",
                                "scoreboard_subtitle":"Live<BR CLEAR=LEFT>Scores"
                            }

                    },
                'activeCategory':'tab2'
                });

    })(jQUery);
</script>




<div id="menuContentsArea" style="display:none;">
    <div id="div_myleagues">
        <ul id="myleagues">
            <!--<li class="myleagues"></li>-->  
        </ul>
    </div>
    <div id="div_forowners">
        <ul id="forowners">
            <!--<li class="forowners"></li>-->
        </ul>
    </div>  
    <div id="div_communications">
        <ul id="communications">
            <!--<li class="communications"></li>-->
        </ul>
    </div>  
</div>  

1 个答案:

答案 0 :(得分:0)

您无法使用$.noConflict。整个碰撞来自两个库,使用$作为别名。

尝试

jQuery.noConflict();
(function($){
    /* within this wrapper "$" is jQuery again*/
     $('#headerTvRotator').innerfade.....

 })(jQUery);

不要在该包装器之外使用带有“$”的任何jQuery代码...否则必须使用完整的jQuery单词,如:

 jQuery('#headerTvRotator').innerfade.....