我怎样才能让这两个javascript文件都能正常工作?

时间:2012-04-16 03:40:09

标签: javascript jquery ajax

我的index.html文件的结尾我包含两个脚本文件。其中一个文件使用jquery处理页面内容。另一个文件处理我操作主页上的选项卡式内容区域,也就是jquery。如果我将文件放在ajax页面加载文件的文件之后的选项卡式内容区域,则标签可以正常工作,但页面加载的ajax不起作用。如果我颠倒了那些文件的顺序,那么页面加载ajax工作但不是选项卡。可能导致这种情况的原因是什么?

以下是选项卡式内容的文件:

$(document).ready(function (){
initialize();
});

function initialize() {
//Click on nav to load external content through AJAX
// $('#topnav a').click(function(e){
//  e.preventDefault();
//  $('#pages').load( e.target.href + ' #loadcontent'); //pages finished loading
// }); //clicked on nav

    $(function() {

    $("#tabedarea").organicTabs();

    $("tabedarea").organicTabs({
        "speed": 200
    });
});
}

(function($) {

$.organicTabs = function(el, options) {

    var base = this;
    base.$el = $(el);
    base.$navtabs = base.$el.find(".navtabs");

    base.init = function() {

        base.options = $.extend({},$.organicTabs.defaultOptions, options);

        // Accessible hiding fix
        $(".hidetabs").css({
            "position": "relative",
            "top": 0,
            "left": 0,
            "display": "none"
        }); 

        base.$navtabs.delegate("li > a", "click", function() {

            // Figure out current list via CSS class
            var curList = base.$el.find("a.current").attr("href").substring(1),

            // List moving to
                $newList = $(this),

            // Figure out ID of new list
                listID = $newList.attr("href").substring(1),

            // Set outer wrapper height to (static) height of current inner list
                $allListWrap = base.$el.find(".list-wrap"),
                curListHeight = $allListWrap.height();
            $allListWrap.height(curListHeight);

            if ((listID != curList) && ( base.$el.find(":animated").length == 0)) {

                // Fade out current list
                base.$el.find("#"+curList).fadeOut(base.options.speed, function() {

                    // Fade in new list on callback
                    base.$el.find("#"+listID).fadeIn(base.options.speed);

                    // Adjust outer wrapper to fit new list snuggly
                    //var newHeight = base.$el.find("#"+listID).height();
                    //$allListWrap.animate({
                    //    height: newHeight
                    //});

                    // Remove highlighting - Add to just-clicked tab
                    base.$el.find(".navtabs li a").removeClass("current");
                    $newList.addClass("current");

                });

            }   

            // Don't behave like a regular link
            // Stop propegation and bubbling
            return false;
        });

    };
    base.init();
};

$.organicTabs.defaultOptions = {
    "speed": 300
};

$.fn.organicTabs = function(options) {
    return this.each(function() {
        (new $.organicTabs(this, options));
    });
};

})(jQuery);  

这是页面加载ajax的文件:

// remap jQuery to $
(function($){})(window.jQuery);


/* trigger when page is ready */
$(document).ready(function (){
    initialize();

});

function initialize() {
    //Click on nav to load external content through AJAX
    $('#topnav a, #bottomnav a').not('#bottomnav #fbcallus a').click(function(e){
        e.preventDefault();
        $('#pages').load( e.target.href + ' #loadcontent'); //pages finished loading
    }); //clicked on nav
    //handle AJAX for left nav

}

2 个答案:

答案 0 :(得分:1)

您正在创建具有相同名称initialize的全局函数,更改其名称或仅更改名称。之后加载的那个会覆盖第一个

答案 1 :(得分:0)

问题是这两个函数的名称相同。为函数使用两个不同的名称。 然后,您不需要添加两个页面加载处理程序。在后一个脚本中添加单个页面加载处理程序并调用其中的两个方法。 假设你的两个函数是initialize()和init2(),那么在后面的js文件中使用

$(document).ready(function () {
   initialize();
   init2();
});