cube-ui indexList的正确使用

demo地址:https://github.com/zphtown/cube-ui-bug

上拉和下拉核心代码:

  onPullingDown () {
      this.isNoMore = false
      this.from = 1
      this.getList(1)
    },
    onPullingUp () {
      if (this.isNoMore) {
        this.$refs.indexList.forceUpdate()
        return
      }
      this.getList()
    },
    getList (isUpdate) {
      axios.get('http://api.zphtown.com/getGoldList.php', {
        params: {
          from: this.from,
          size: this.size
        }
      })
      .then(res => {
        const { list } = res.data
        const len = list.length
        let arr = []
        list.map(v => {
          let time = parseTime(v.createTime, '{y}年{m}月')
          let index = arr.findIndex(v2 => v2.name === time)
          if (index === -1) {
            arr.push({
              name: time,
              items: []
            })
          }
          arr[index > -1 ? index : arr.length - 1].items.push(v)
        })
        if (isUpdate) {
          if (len) {
            this.list = arr
          } else {
            this.$refs.indexList.forceUpdate()
          }
        } else {
          arr.map(v => {
            let index = this.list.findIndex(v2 => v2.name === v.name)
            if (index > -1) {
              this.list[index].items.push(...(v.items))
            } else {
              this.list.push(v)
            }
          })
          if (len) {
            if (len === this.size) {
              setTimeout(() => {
                this.$refs.indexList.forceUpdate(true)
              }, 30)
            } else {
              console.log('nodata')
              this.isNoMore = true
              setTimeout(() => {
                this.$refs.indexList.forceUpdate(true, true)
              }, 30)
            }
          } else {
            this.$refs.indexList.forceUpdate()
            this.isNoMore = true
          }
          this.from++
        }
      })
    }
  }

 

划重点:

 

转载于:https://www.cnblogs.com/zph666/p/11069344.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值