实现无限加载功能

本文介绍了如何利用jQuery开发无限滚动功能,包括HTML结构设置、判断触底加载新内容的逻辑、动画效果和防止重复加载的处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 无限滚动功能通常是通过监听滚动事件,并在用户滚动到页面底部时自动加载更多内容来实现的。以下以jQuery为例来说明如何实现无限滚动:

首先,你需要在HTML中设置一个容器来显示内容,还可以设置一个等待加载新内容时的动画(初始时可能是隐藏的)。

 * {
            margin: 0;
            padding: 0;
        }
        .content-container {
            margin: 50px 50px 0 50px;
        }
        #content-item {
            border: 1px solid #000;
            height: 150px;
            width: 150px;
            margin: 20px;
        }
        #loading {
            display: none;
            margin: auto;
            width: 60px;
            aspect-ratio: 2;
            --_g: no-repeat radial-gradient(circle closest-side,#4e4b4b 90%,#0000);
            background: 
                var(--_g) 0%   50%,
                var(--_g) 50%  50%,
                var(--_g) 100% 50%;
            background-size: calc(100%/3) 50%;
            animation: l3 1s infinite linear;
            }
            @keyframes l3 {
                20%{background-position:0%   0%, 50%  50%,100%  50%}
                40%{background-position:0% 100%, 50%   0%,100%  50%}
                60%{background-position:0%  50%, 50% 100%,100%   0%}
                80%{background-position:0%  50%, 50%  50%,100% 100%}
        }

实现的主要思路:

通过滚动区域高度+可视区域高度>=文档总高度来判断是否用户滑动页面时是否已经触底。若已触底则发送请求加载新内容。

 //循环创建img
        function content(){
            for (let i = 1; i <= 18; i++) {
            let img = document.createElement("img")
            img.src = `img/1 (${i}).jpg`
            img.id ="content-item"
            let box = document.getElementsByClassName("content-container")[0]
            box.appendChild(img)
        }
        }
        //创建初始内容
        content()
        $(document).ready(function () {
            // 用于防止在加载过程中重复触发加载,否则用户在等待加载时往上滑再往下滑时会重复触发
            var isLoading = true;  
            var page = 1; // 当前页码,用于向服务器请求更多内容  
            // 监听滚动事件  
            $(window).scroll(function () {
                //滚动区域高度+可视区域高度>=文档总高度时
                if ($(window).scrollTop() + $(window).height() >= $(document).height() && isLoading) {
                    loadMoreContent();
                }
            });

            // 加载更多内容  
            function loadMoreContent() {
                isLoading = false; // 防止重复触发  
                $('#loading').show(); // 显示加载更多按钮  
                setTimeout(function(){//用定时器模仿发送请求以及加载耗时
                    content()
                    isLoading = true; // 加载完成,将加载状态设置为false 
                },2000)
            }
            });

好的,我可以为您提供关于使用vue-infinite-loading实现php无限加载的一些指导。 首先,您需要安装vue-infinite-loading。可以通过npm或yarn安装,具体操作为: ``` npm install vue-infinite-loading --save ``` 或 ``` yarn add vue-infinite-loading ``` 安装完成后,在您的Vue组件中引入该组件: ```javascript import InfiniteLoading from 'vue-infinite-loading'; export default { components: { InfiniteLoading, }, }; ``` 接下来,您需要在组件的template中使用该组件,并在data中定义需要加载数据列表和当前页码: ```html <template> <div> <ul> <li v-for="item in list" :key="item.id">{{ item.title }}</li> </ul> <infinite-loading @infinite="infiniteHandler"></infinite-loading> </div> </template> <script> export default { data() { return { list: [], page: 1, }; }, methods: { infiniteHandler($state) { // 这里使用ajax请求获取数据,page为当前页码 axios.get('/api/list', { params: { page: this.page, }, }).then((res) => { if (res.data.length > 0) { this.list = this.list.concat(res.data); this.page += 1; $state.loaded(); } else { $state.complete(); } }); }, }, }; </script> ``` 在上面的代码中,我们使用axios发送ajax请求获取数据,并在请求成功后使用concat方法将新数据追加到原数据列表中。同时,我们使用$state.loaded()方法告诉vue-infinite-loading组件数据已经加载完毕,可以继续加载下一页数据。如果返回的数据为空,则使用$state.complete()方法告诉vue-infinite-loading组件数据已经全部加载完毕。 最后,您需要在样式中设置vue-infinite-loading组件的高度和样式: ```css .vue-infinite-loading { height: 60px; line-height: 60px; text-align: center; } ``` 这样就完成了使用vue-infinite-loading实现php无限加载的操作。希望以上内容能够对您有所帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值