ajax鼠标滚动到网页底部实现局部刷新~瀑布流

<!DOCTYPE html>
<html>
    <head>
        <meta charset="UTF-8">
        <title>瀑布流</title>
        <link rel="stylesheet" href="base.css" />
        <script src="ourAjax.js"></script>
        <script>
            window.onload = function(){
                var cols = document.querySelectorAll(".col");//选择器dom操作方法  //通过选择器拿到对应标签
                document.body.οnscrοll=document.documentElement.onscroll = function(){//特殊的兼容写法,兼容滚动高度
                    ajax({
                        method:"get",
                        url:"data.json",//通过地址直接请求数据
                        success:function(data){               //数据请求成功之后执行的处理程序
                            var obj = JSON.parse(data);       //将请求得到的json格式的数据转化为可以使用的json对象
                            //console.log(obj);
                            //当前浏览器的高度
                            var cHeight = document.documentElement.clientHeight;
                            //滚动条距离顶部的距离
                            var sTop = document.body.scrollTop||document.documentElement.scrollTop;
                            //文档的高度
                            var pHeight = document.body.scrollHeight;
                            document.title = cHeight;
                            //alert(1)
                            var flag = cHeight + sTop==pHeight;//滚动条距离顶部的距离+当前浏览器的高度==文档的高度为真
                            if(flag){
                                addImg(obj.datas);添加图片
                            }
                            
                            
                            
                            
                        },
                        error:function(mes){
                            //console.log(mes)
                        }
                    })
                }
                
                function addImg(arr){
                    for(var i = 0;i<arr.length;i++){
                        var box = document.createElement("div");
                        box.className = "box";
                        box.innerHTML = '<img src="images/'+arr[i]+'"  />';
                        var col = getMinHeight(cols);
                        col.appendChild(box);
                        
                    }
                }
                
                /*
                   高度最小的列dom对象
                */
                function getMinHeight(cols){
                    var min = cols[0];  //高度最小的列dom对象
                    for(var i = 0;i<cols.length;i++){
                        if(min.offsetHeight>cols[i].offsetHeight){
                            min = cols[i];
                        }
                    }
                    return min;
                }
            }
        </script>
        
    </head>
    <body>
        <div id="container">
            <div class="col">
                <div class="box">
                    <img src="images/0.jpg"  />
                </div>
                <div class="box">
                    <img src="images/4.jpg"  />
                </div>
                <div class="box">
                    <img src="images/5.jpg"  />
                </div>
            </div>
            <div class="col">
                <div class="box">
                    <img src="images/1.jpg"  />
                </div>
                <div class="box">
                    <img src="images/4.jpg"  />
                </div>
                <div class="box">
                    <img src="images/6.jpg"  />
                </div>
            </div>
            <div class="col">
                <div class="box">
                    <img src="images/2.jpg"  />
                </div>
                <div class="box">
                    <img src="images/0.jpg"  />
                </div>
            </div>
            <div class="col">
                <div class="box">
                    <img src="images/3.jpg"  />
                </div>
                <div class="box">
                    <img src="images/8.jpg"  />
                </div>
                <div class="box">
                    <img src="images/9.jpg"  />
                </div>
            </div>
        </div>
    </body>

</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值