js防抖和节流优化浏览器滚动条滚动到最下面时加载更多数据

  防抖和节流,主要是用来防止过于平凡的执行某个操作,如浏览器窗口变化执行某个操作,监听某个input输入框keyup变化,瀑布流布局时Y轴滚动,图片加载。

    js函数的防抖

      经过一段事件才执行某个操作,如果时间内又执行了该操作则延长时间重新开始计算

/* 不做处理input触发keyup事件 */

/* 输入快的话会出现输出结果多次重复 */

window.onload = function () {
    let obj = document.getElementById(‘input‘)
    obj.addEventListener(‘keyup‘,()=>{
        let val = obj.value;
        inputchange(val)
    },false)
}
function inputchange(val) {
    console.log(val)
}// 11  11  123 123  123456 123456 123456

  使用防抖去处理

/* 使用防抖去处理input触发keyup事件 */
/* 输入快的话会也不会输出多次重复结果 */
window.onload = function () {
    let obj = document.getElementById(‘input‘)
    let callback = inputchange()
    obj.addEventListener(‘keyup‘,()=>{
        let val = obj.value;
        callback(val)
    },false)
}
// 高级函数的应用
// 闭包time为局部变量 但不会在inputchange 函数调用完后释放
// 函数返回函数
function inputchange() {
    var time
    return function(val){
        if(time)
        {
            clearTimeout(time)
        }
        time = setTimeout(() => {
            console.log(val)
        }, 200);
    }
}

    js函数节流

      定义:执行某个操作后一段时间内不在不行该操作

/* 使用节流去处理input触发keyup事件 */
/* 输入快的话会也不会输出多次重复结果 */
window.onload = function () {
    let obj = document.getElementById(‘input‘)
    let callback = inputchange()
    obj.addEventListener(‘keyup‘,()=>{
        let val = obj.value;
        callback(val)
    },false)
}
// 使用闭包保存hasdone
function inputchange() {
    var hasdone = false
    return function(val){
        // 如果已经执行 hasdone = true 则直接返回
        if(hasdone)
        {
            return;
        }
        // 设置已经执行
        console.log(val)
        hasdone =true
        /* 一段时间后设置hasdone 为能够再次执行 */
        time = setTimeout(() => {
            hasdone = false
        }, 2000);
    }
}

  上面的节流,第一次输入马上执行,是最后输入不执行。

  还有就是第一次输入不马上执行,时间内最后执行

/* 使用节流去处理input触发keyup事件 */
/* 输入快的话会也不会输出多次重复结果 */
window.onload = function () {
    let obj = document.getElementById(‘input‘)
    let callback = inputchange()
    obj.addEventListener(‘keyup‘,()=>{
        let val = obj.value;
        callback(val)
    },false)
}
// 使用闭包保存hasdone
/* 时间内不马上执行,时间段内只执行一次 */
function inputchange() {
    var hasdone = false
    var time = null
    return function(val){
        // 如果已经执行 hasdone = true 则直接返回
        if(hasdone)
        {
            return;
        }
        // 设置已经执行
        hasdone =true
        /* 一段时间后设置hasdone 为能够再次执行 */
        time = setTimeout(() => {

            console.log(val)
            hasdone = false
        }, 500);
    }
}

js 实现浏览器滚动条滚动到最下面时,加载更多数据

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script src="./js/fangdouhejl.js"></script>
    <style>
        .box{
            height:890px;
        }
        li{
           height: 60px;
        }
        .loading{
            width: 80px;
            height: 40px;
            margin: 0 auto;
            margin-top:100px;
            display: none;
        }
        .loading span{
            display: inline-block;
            width: 8px;
            height: 100%;
            border-radius: 4px;
            background: lightgreen;
            -webkit-animation: load 1s ease infinite;
        }
        @-webkit-keyframes load{
            0%,100%{
                height: 40px;
                background: lightgreen;
            }
            50%{
                height: 70px;
                margin: -15px 0;
                background: lightblue;
            }
        }
        .loading span:nth-child(2){
            -webkit-animation-delay:0.2s;
        }
        .loading span:nth-child(3){
            -webkit-animation-delay:0.4s;
        }
        .loading span:nth-child(4){
            -webkit-animation-delay:0.6s;
        }
        .loading span:nth-child(5){
            -webkit-animation-delay:0.8s;
        }
    </style>
</head>
<body>
    <ul id="box">
        <li>baojia1</li>
        <li>baojia2</li>
        <li>baojia3</li>
        <li>baojia4</li>
        <li>baojia5</li>
        <li>baojia6</li>
        <li>baojia7</li>
        <li>baojia8</li>
        <li>baojia9</li>
        <li>baojia10</li>
        <li>baojia11</li>
        <li>baojia12</li>
        <li>baojia13</li>
        <li>baojia14</li>
        <li>baojia15</li>
        <li>baojia16</li>
        <li>baojia17</li>
        <li>baojia18</li>
        <li>baojia19</li>
        <li>baojia20</li>
    </ul>
    <div class="loading" id="loading">
        <span></span>
        <span></span>
        <span></span>
        <span></span>
        <span></span>
    </div>
</body>
</html>
/* 浏览器滚动事件onsroll */
/* 实现浏览器滚动到最下面实现加载 */
var loadmore = loadmoreresource ();
/* 模仿滚到最下面继续加载数据 */
window.onscroll = function (e) {
    /* 判断是否滚到最下面 */
    /* 如果已经滚到最下面则执行某个操作 */
    var e =e || window.event;
    // 为了兼容谷歌和火狐 document.body.scrollTop是谷歌上的
    /* 滚动条的垂直位置 */
    var scrolltop = document.documentElement.scrollTop||document.body.scrollTop;
    /* 整个页面的正文高度 */
    var scrollHeight = document.documentElement.scrollHeight||document.body.scrollHeight;
    /* 可见区域高度 */
    var clientHeight = document.documentElement.clientHeight||document.body.clientHeight;

    /* 当scrolltop加clientHeight 等于scrollHeight */
    if(scrollHeight === (scrolltop+clientHeight))
    {
        loadmore();
    }
}

/* 往下拉时加载的数据 */
/* 使用函数节流优化加载,否则会出现一次性加载很多次 */
function loadmoreresource () {
    let  i = 21;
    /* 定义是否已经加载 */
    let isloading = false;
    return function () {
        /* 假如已经在加载中了则直接返回 */
        if(isloading) {
            return;
        }
        /* 出现加载动画 */
        loadingimg()
        let obj = document.getElementById(‘box‘);
        /* 代码片段 用于插入多个标签 */
        let docfragment = document.createDocumentFragment();
        for(let j=0;j<5;j++){
            let li = document.createElement(‘li‘)
            li.append(‘baojia‘+i)
            docfragment.appendChild(li)
            i++;
        }
        /* 设置当前加载的状态为true */
        isloading = true;
        /* 使用setTimeout 模拟从api加载数据 */
        setTimeout(() => {
            obj.appendChild(docfragment)
            loadingimg()
            /* 将加载状态设置为false */
            isloading = false
        }, 3000);
    }
}
/* 加载动画 */

function loadingimg() {
    let loading = document.getElementById(‘loading‘);
    if(loading.style.display===‘block‘) {
        loading.style.display = ‘none‘;
    } else {
        loading.style.display = ‘block‘;
    }
}

原文地址:https://www.cnblogs.com/czkolve/p/10859176.html

时间: 2024-10-12 04:28:43

js防抖和节流优化浏览器滚动条滚动到最下面时加载更多数据的相关文章

下拉滚动加载更多数据

简单地实现一个下拉滚动时加载更多数据的效果.这种效果经常在手机端.瀑布流时看到 1 KISSY.add('load',function(S,Core,IO,XTemplate){ 2 var $ = S.all, D = S.DOM, E = S.Event; 3 var API = { 4 'query':'query.do' 5 }; 6 var tpl = '{{#each result}}'+ 7 '<tr>'+ 8 '<td><input type="ch

当滚动条滚动到页面底部自动加载增加内容的js代码

这篇文章主要介绍了如何使用javscript实现滚动条滚动到页面底部自动加载增加页面内容,需要的朋友可以参考下..1,注册页面滚动事件,window.onscroll = function(){ }; 2,相关获取页面高度.滚动条位置.文档高度的函数: 复制代码 代码如下://获取滚动条当前的位置 function getScrollTop() { var scrollTop = 0; if (document.documentElement && document.documentEle

vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件

vue10行代码实现上拉翻页加载更多数据,纯手写js实现下拉刷新上拉翻页不引用任何第三方插件/库 一提到移动端的下拉刷新上拉翻页,你可能就会想到iScroll插件,没错iScroll是一个高性能,资源占用少,无依赖,多平台的javascript滚动插件.iScroll不仅仅是 滚动.它可以处理任何需要与用户进行移动交互的元素.在你的项目中包含仅仅4kb大小的iScroll,你的项目便拥有了滚动,缩放,平移,无限滚动,视差滚动,旋转功能.iScroll的强大毋庸置疑,本人也非常欢迎大家使用iScr

vue.js中滚动条加载更多数据

本文章参考:http://www.cnblogs.com/ssrsblogs/p/6108423.html 分析:1.需要判断滚动条是否到底部: 需要用到DOM的三个属性值,即scrollTop.clientHeight.scrollHeight. scrollTop为滚动条在Y轴上的滚动距离. clientHeight为内容可视区域的高度. scrollHeight为内容可视区域的高度加上溢出(滚动)的距离. 从这个三个属性的介绍就可以看出来,滚动条到底部的条件即为scrollTop + cl

Jquery鼠标滚动到页面底部自动加载更多内容,使用分页

https://www.cnblogs.com/qhorse/p/4717726.html index.php代码 [html] view plaincopy<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://

angularjs 滚动加载更多数据

下面的例子只是为了简单记录怎么使用angularjs来实现滚动加载数据,具体的还是需要具体看待: Javascript部分的controller app.controller('AnalysizerCtrl', ['$scope', '$timeout', '$window',     function ($scope, $timeout, $window) {             $scope.showData = false;                 $scope.isLoadi

vue 实现滚动到页面底部开始加载更多

直接上代码: <template> <div class="newsList"> <div v-for="(items, index) in newsList"> <div class="date">{{showDay(index)}}</div> <div class="list" > <ul> <li class="list

基于 Vue.js 的移动端组件库mint-ui实现无限滚动加载更多

通过多次爬坑,发现了这些监听滚动来加载更多的组件的共同点, 因为这些加载更多的方法是绑定在需要加载更多的内容的元素上的, 所以是进入页面则直接触发一次,当监听到滚动事件之后,继续加载更多, 所以对于无限滚动加载不需要写首次载入列表的函数, 代码如下: html: //父组件 <div v-infinite-scroll="loadMore" infinite-scroll-disabled="loading" infinite-scroll-distance=

UITableview优化随笔(1)-提高加载更多内容时的效率

UITableView上拉加载更多的功能相信很多应用都会用到,类似朋友圈.微博这样的应用,tableView中的数据内容高度根据内容来变化,同时需要加载大量的数据(上拉加载更多),要怎样才能保证加载数据时的页面流畅呢? UITableView的原理和使用,以及其滚动帧率的优化,不是本篇blog要讨论的问题,这个在网上能搜到大量资料,这里不再赘述. 一般在实现上拉加载更多数据的实现思路是: 1.获取新的数据 2.在当前dataArray中添加这些数据 3.在tableView上显示这些数据 其中第