Vue无限加载vue-infinite-loading使用详解

 

如何安装

npm install vue-infinite-loading --save

导入方式

es6模块导入方式
import InfiniteLoading from 'vue-infinite-loading';
export default {
  components: {
    InfiniteLoading
  },
};
CommonJS 模块导入方式
const InfiniteLoading = require('vue-infinite-loading');
export default {
  components: {
      InfiniteLoading
  }
};
其他方式
<script src="vue-infinite-loading.js"></script>

在页面中应用

直接在组件中声明
components:{
   InfiniteLoading
}

模板部分

<infinite-loading @infinite="infiniteHandler"  :distance="200" ref="infiniteLoading" class="infinite-loading-wrap">
                   <div v-if="pageNum === 1" slot="spinner"></div>
                    <div v-else slot="spinner" class="loading-spinner">
                        <div class="dot"></div><div class="dot"></div><div class="dot">                                    
                        </div>
                    </div>
                    <div slot="no-results" class="empty-font">当前数据为空</div>
                    <div slot="no-more" class="empty-font">我们是有底线的</div>
</infinite-loading>

js部分 

data: function() {
        return  {
          ai: [{
                    "user": "你好呀!",
                    "userdate": uill.Format(new Date(), "MM/dd hh:mm")
                },
                 {
                    "ar": "你好!",
                    "ardate": uill.Format(new Date(), "MM/dd hh:mm")
                }],
              pageNum: 0
        }
    }, 
methods: {
infiniteHandler($state) {
           //console.log(this.url)
           console.log(123)
                setTimeout(() => {
                    const temp = [{
                    "user": "你好呀!",
                    "userdate": uill.Format(new Date(), "MM/dd hh:mm")
                },
                 {
                    "ar": "你好!",
                    "ardate": uill.Format(new Date(), "MM/dd hh:mm")
                },
                {
                    "user": "你叫什么名字?",
                    "userdate": uill.Format(new Date(), "MM/dd hh:mm")
                }];
                    this.ai = this.ai.concat(temp);
                    console.log(this.ai)
                    $state.loaded();//一直有数据显示
                    this.indexone++;
                    if(this.indexone === 1){
                        $state.complete();
                    }
                  
                }, 1000);
                
        }
}

注意

如果还是使用
this.$refs.infiniteLoading.$emit('$InfiniteLoading:loaded');
this.$refs.infiniteLoading.$emit('$InfiniteLoading:complete');
会出现警告,告诉你已经修改为传参传入$state使用这个方法。

属性

distance:这是滚动的临界值。如果到滚动父元素的底部距离小于这个值,那么infiniteHandler回调函数就会被调用。
<infinite-loading @infinite="infiniteHandler"  distance="Number">
</infinite-loading>
spinner:通过这个属性,你可以选择一个你最喜爱旋转器作为加载动画。
spinner="bubbles";
1、bubbles
2、circles
3、default 
4、spiral 
5、waveDots
<infinite-loading @infinite="infiniteHandler"  spinner="String">
</infinite-loading>
direction:如果你设置这个属性为top,那么这个组件将在你滚到顶部的时候,调用infiniteHandler函数。
警告:你必须在数据加载后,手动地将滚动父元素的scrollTop设置为正确的值,否则,该组件会一次又一次调用infiniteHandler函数。
direction="top"
<infinite-loading @infinite="infiniteHandler"  direction="String">
</infinite-loading>

当加载到底部后重置需要执行

this.$refs.infiniteLoading.$emit('$InfiniteLoading:reset');
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,我可以为您提供关于使用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、付费专栏及课程。

余额充值