仅在Bootstrap模式打开后延迟加载图像

时间:2016-10-06 00:23:15

标签: javascript jquery lazy-loading bootstrap-modal

我在这里找到了两个相似的答案,但两个都没有成功解决我的情况(因为我将它们转化为我的情况的能力有限)。我有一个页面有很多相当大的图像,Bootstrap的默认方法是在页面加载时加载所有模态图像。可见的html渲染速度相当快(我有一个微调器),但隐藏模态的额外加载时间使得页面不切实际。我希望页面只加载可见(非模态)内容以完成页面加载(并清除微调器),然后仅在触发该模式时加载每个模态的内容。我已经尝试了我能找到的每个延迟加载解决方案,但图像不会在模态中呈现(' data-src'占位符渲染但不是#c; src'图像替换他们)。我只想懒惰(或加载' show.bs.modal')模态的大图像,那些在模态体内的图像'类。我希望这很清楚。

示例代码:

/* Javascript placed in the head */

<script>

function lazyLoad(){
    var $images = $('.lazy_load');

    $images.each(function(){
        var $img = $(this),
            src = $img.attr('data-src');

        $img
            .on('load',imgLoaded($img[0]))
            .attr('src',src);
        });
    };

    $('.modal-body').on("show.bs.modal", function () {
    lazyLoad();
};          

</script>

/* HTML in the modal section */


<div class="portfolio-modal modal fade" id="portfolioModal1" tabindex="-1" role="dialog" aria-hidden="true">
        <div class="modal-content">
            <div class="galleryheader">
                <img src="headerimage_1.png" height="77" width="1024">
            </div>
            <div class="close-modal" data-dismiss="modal">
                <div class="lr">
                    <div class="rl">
                    </div>
                </div>
            </div>
            <div class="container">
                <div class="row">
                    <div>
                        <div class="modal-body lazy_load">
                            <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" data-src="images/largeimage_1A.jpg" height="585" width="800"class="img-centered" alt=""/>
                        </div>
                        <div class="modal-body lazy_load">
                            <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" data-src="images/largeimage_1A.jpg" height="585" width="800"class="img-centered" alt=""/>
                        </div>
                        <div class="modal-body lazy_load">
                            <img src="data:image/gif;base64,R0lGODlhAQABAIAAAAAAAP///yH5BAEAAAAALAAAAAABAAEAAAIBRAA7" data-src="images/largeimage_1A.jpg" height="585" width="800"class="img-centered" alt=""/>
                        </div>
                    </div>
                </div>
            </div>

                <div class="close-lower" data-dismiss="modal">
                <IMG SRC="images/close.jpg" WIDTH="85" HEIGHT="32"></a>
                </div>
            </div>
        </div>
</div>

1 个答案:

答案 0 :(得分:4)

首先,将lazy_load类放在img元素上,而不是放在父div上。其次你需要的jQuery是这样的:

$('.portfolio-modal').on("show.bs.modal", function () {
    $('.lazy_load').each(function(){
        var img = $(this);
        img.attr('src', img.data('src'));
    });
});          

注意:

  1. 使用portfolio-modal类来识别模态。
  2. 使用jQuery data()方法让图片延迟加载。