zoukankan      html  css  js  c++  java
  • JS实现图片懒加载demo

    <!DOCTYPE html>
    <html>
    <head>
        <script src="http://apps.bdimg.com/libs/jquery/1.9.1/jquery.js"></script>
        <title>demo lazyload</title>
        <meta charset="utf-8">
        <style type="text/css">
            * {
                padding: 0;
                margin: 0;
                text-decoration: none;
                list-style: none;
            }
            .layout {
                margin: 0 auto;
                width: 1000px;
            }
            .lazyload img {
                width: 300px;
                height: 400px;
            }
            .img-ct {
                margin-left: -50px;
                overflow: auto;
            }
            .item {
                float: left;
                margin-left: 50px;
                margin-bottom: 30px;
            }
        </style>
    </head>
    <body>
    <div class="lazyload">
      <div class="layout">
        <ul class="img-ct">
            <li class="item">
                <a href="javascript:void(0)"><img data-img="1.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="1.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="1.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="1.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="2.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="2.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="2.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="2.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="2.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="3.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="3.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="3.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="3.png" src="default.png"></a>
            </li>
            <li class="item">
                <a href="javascript:void(0)"><img data-img="3.png" src="default.png"></a>
            </li>
        </ul>
      </div>
    </div>
    
    <script type="text/javascript">
    var lazyLoad = (function(){
        var clock;
        
        function init(){
            $(window).on("scroll", function(){
                if (clock) {
                    clearTimeout(clock);
                }
                clock = setTimeout(function(){
                    checkShow();
                }, 200);
            })
            checkShow();
        }
        
        function checkShow(){
            $(".lazyload img").each(function(){
                var $cur =$(this);
                if($cur.attr('isLoaded')){
                    return;
                }
                if(shouldShow($cur)){
                    showImg($cur);
                }
            })
        }
    
        function shouldShow($node){
            var scrollH = $(window).scrollTop(),
                winH = $(window).height(),
                top = $node.offset().top;
    
            if(top < winH + scrollH){
                return true;
            }else{
                return false;
            }
        }
    
        function showImg($node){
            $node.attr('src', $node.attr('data-img'));
            $node.attr('isLoaded', true);
        }
    
        return {
            init: init
        }
    })()
    
    lazyLoad.init();
    </script>
    </body>
    </html>
  • 相关阅读:
    Javascript typeof 用法
    查询指定范围内数据记录(适用于sqlserver2005以上)
    提示信息并跳转的目标URL
    教你如何删除MSN群
    通过sqlserver2005 获取客户端信息
    分层遍历数据
    重写render,利用ClientScript,在客户端注册select,回发到服务器,触发服务器端的行选择事件。
    ASP.NET下的TreeView控件的使用(生成树与统计所有子节点数量)
    后台取浏览器中cookie的用法
    jdk开发环境的搭建
  • 原文地址:https://www.cnblogs.com/chenjiacheng/p/7232392.html
Copyright © 2011-2022 走看看