$(窗口).resize事件无法正常工作100%

时间:2012-11-12 15:33:45

标签: javascript jquery

我在页面(#home)上运行以下代码,该代码应该平滑地注入滑块,或者如果页面容器小于480px,则按原样保留页面。

我无法让调整大小事件顺利完成。

如果我缩小窗口,脚本(js.slide.js)将不会被触发,但内容将被加载(slide.php)。如果我继续减少窗口,那么一切都会正常工作。

有人可以建议我如何顺利地完成这项工作。代码如下

$(document).ready(function(){

if ($("#home").length > 0 ){ 

var homeSlideShow = {
    $promoArea: $('#promo-area'),
    $currentContent: $('#promo-area').contents(),
    $pageContainer: $('.page'),

    init: function(){
        var hSS = homeSlideShow;            
        if (hSS.$pageContainer.width() > 480 ){
            hSS.setTheSlideShow();
        } else{
            hSS.$promoArea.html(hSS.$currentContent);
        }

    },

    setTheSlideShow: function(){
        var hSS = homeSlideShow;                        
        $.getScript(myscript_wp_vars.temp_dir + '/js/slide.js', function(){
        hSS.$promoArea.load(myscript_wp_vars.temp_dir + '/libs/slide.php #c4u-slide',
        function(){
        var options = {
                    preloader: false,
                    nextButton: true,
                    prevButton: true,
                    animateStartingFrameIn: true,
                    transitionThreshold: 250                        
                };

                var sequence = $("#sequence").sequence(options).data("sequence"),
                    $slideShow = $("#c4u-slide");
                });

        });
    }   

};




//
//  Check page size
//
if (homeSlideShow.$pageContainer.width() > 480 ){
    homeSlideShow.setTheSlideShow();
}



//
//  On window resize
//
$(window).resize(function() {   
    homeSlideShow.init();   
});

}// END home.length

});//End $(document).ready(function()

提前感谢您的任何帮助或建议。

干杯

诺尔

1 个答案:

答案 0 :(得分:2)

根据浏览器的行为,会多次触发

window.resize事件。我建议你试试这个:

var timeoutResize;
$(window).resize(function(){ 
        if(typeof timeoutResize != 'undefined') clearTimeout(timeoutResize);
        timeoutResize = setTimeout(function(){homeSlideShow.init();},50);

    });