uni-app 表格后端不分页加载更多封装的js

status:判断加载文字和是否继续进行加载
partData:传给table显示的数据
allData:总数据

const tableMore = {
	status: 0,
	text: ['加载更多...', '拼命加载中!', '收起']
}
const isMore = (status,partData,allData) => {
	let partLength = partData.length
	let allLength = allData.length
	let partLengthMore = partLength+10
	let obj = {}
	if(status == 0){
		if(partLength != allLength.length){
			tableMore.status = 1
			// this.$set(tableMore,'status',1)
			if(partLengthMore <= allLength){
				if(partLengthMore < allLength){
					tableMore.status = 0
				}else if(partLengthMore = allLength){
					tableMore.status = 2
				}
				partData = partData.concat(allData.slice(partLength,partLengthMore))
			}else{
				partData = partData.concat(allData.slice(partLength,allLength))
				tableMore.status = 2
			}
			
		}else{
			tableMore.status = 2
		}
	}else if(status == 2){
		partData = allData.slice(0,10)
		tableMore.status = 0
	}
	obj = {
		status:tableMore.status,
		text:tableMore.text[tableMore.status],
		data:partData
	}
	// console.log(obj);
	return obj

}
export {

	isMore

}

index.vue文件

<text @tap="rainTableIsMore(tableMore.status)">{{tableMore.text}}</text>
import { isMore } from '@/utils/application/isMore.js'
export default{
  data(){
    return {
      tableMore:{
		status:0,
		text:'',
	  },
	  rainTableData:[],
	  rainfall2:[],
    }
  },
  methods:{
  getRainSection(data){
	rainSection(data).then(res=>{
		if(res.status == 200){
			this.rainTableData = res.data
			let obj =isMore(0,this.rainfall2,res.data)
						this.changeRainfallTableData(obj)
					}
				})
			},
			
			rainTableIsMore(val){
				let obj = isMore(val,this.rainfall2,this.rainTableData)
				this.changeRainfallTableData(obj)
			},
			
			changeRainfallTableData(obj){
				this.tableMore.status = obj.status
				this.tableMore.text = obj.text
				this.rainfall2 = Object.assign([],obj.data)
			},
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值