vantui列表数据展示,上拉加载下一页,下拉刷新页面

直接上代码:

<div class="profly-layout">
    <van-pull-refresh v-model="refreshing" @refresh="onRefresh" loosing-text="释放刷新" pulling-text="下拉刷新" success-text="刷新成功">
           <van-list
              v-model="loading"
              :finished="finished"
              finished-text="没有更多啦"
              offset="58"
              :immediate-check="false"
             @load="onLoad">
              <div class="item" v-for="(item, index) in list" :key="index">
                <p>{{ index+1 }}</p>
                <p>{{ item.addtime }}</p>
                <p>{{ item.id }}</p>
              </div>
           </van-list>
         </van-pull-refresh>
    </div> 

js:

<script>

import { List, PullRefresh } from 'vant';
export default {
  data() {
    return{
      list: [],
      loading: false, //上拉加载
      finished: false, //上拉加载完毕
      refreshing: false, //下拉刷新
      pageno: 1,
      pagesize:10, //分页条数
    }
  },
  components:{
    [List.name]: List,
    [PullRefresh.name]:PullRefresh,
  },
  created () {
        
  },
  mounted(){
    	this.getData()
  },
  methods:{    
    onRefresh() { //下拉刷新
         this.getData()
     },
     onLoad() { //上拉加载下一页
       let data = {
        sort:"addtime desc",
        pageno: this.pageno,
        pagesize: this.pagesize 
      }
         this.$axios.post("/syJdc/service/findRecord", data).then( res => {
           let datas = res.data.queryResult
            this.list = this.list.concat(datas)
             if (this.list.length < res.data.rowCount) {
                this.pageno++
                 this.loading = false
            }else{
               this.finished = true
                 this.loading = true
             }
         })
     },
    async getData() {
      let data = {
        sort:"addtime desc",
        pageno: this.pageno,
        pagesize: this.pagesize 
      }
      this.$axios.post("/syJdc/service/findRecord", data).then( res => {
             this.list = res.data.queryResult ;   //res.data.queryResult是列表集合
             // rowCount 是后台返回的列表总条数
             if(res.data.rowCount === this.list.length){
                 this.finished = true;
             }else {
                 this.finished = false;
             }
             this.pageno++;
             this.refreshing = false;
             this.loading = false;
         })   
    }
  }
    
}
</script>

css:

.profly-layout {
  .item {
    width: 100%;
    border: 1px solid blue;
    margin-bottom: 20px;
    text-align: center;
    line-height: 26px;
    box-sizing: border-box;
  }
}

效果:
在这里插入图片描述
总结:在写样式的时候一定要注意留心观察请求,本人遇到过某些样式会导致页面疯狂请求数据,具体原因不详

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值