uniapp H5 实现上拉刷新 以及 下拉加载

uniapp H5 实现上拉刷新 以及 下拉加载

1. 先上图

下拉加载
在这里插入图片描述
在这里插入图片描述

2. 上代码

<script>
	import DragableList from "@/components/dragable-list/dragable-list.vue";
	import {
		FridApi
	} from '@/api/warn.js'
	export default {
		data() {
			return {
				tableList: [],
				loadingHide: false,
				isRefreshing: false,
				loadMoreStatus: 'loading', // loading | more | noMore
				pageSize: 10,
				pageNum: 1
			}
		},
		components: {
			DragableList
		},
		mounted() {
			//获取告警列表
			this.getWarnList()
			this.loadMoreStatus = 'loading'
		},
		methods: {
		    // 下拉刷新
			refreshList() {
				this.getWarnList(true)
			},
			// 上拉加载
			loadMore() {
				console.log('list loadMore');
				if (this.tableList.length >= this.total){
					this.loadMoreStatus = 'noMore'
					 return
				}
				this.pageNum++
				this.getWarnList()
			},
			//获取告警列表
			getWarnList(isReload = false) {
				this.loadingHide = true
				this.loadMoreStatus = 'loading'
				// 请将该方法中的请求 更换为你自己的请求
				const params = {
					pageSize: this.pageSize,
					pageNum: this.pageNum,
					noiseReductionStatus: '0',
					alarmIsRecovery: '0',
					alarmSourceId: uni.getStorageSync('alarmSourceId'),
				}
				if (isReload) {
					this.pageNum = 1
					this.isRefreshing = true
					this.tableList = []
				}
				let list = []
				let baseLen = this.tableList.length

				FridApi.warnList(params)
					.then((result) => {
						this.loadingHide = true
						const res = result
						if (res.code === 0 && res.data) {
						   // 一下代码比较重要
							const data = res.data
							list = data.list
							const total = data.total
							this.tableList.push(...list)
							this.total = total
							if (this.tableList.length >= this.total) {
								this.loadMoreStatus = 'noMore'
							} else {
								this.loadMoreStatus = 'more'
							}
							this.isRefreshing = false
						}
					})
					.finally(() => {
						this.loadingHide = false
					})
			}
		}
	}
</script>

<template>
	<view class="mp-count-alarmin">
		<!-- 告警列表 -->
		<dragable-list v-if="!hideShow" :is-refreshing="isRefreshing" :load-more-status="loadMoreStatus"
			@loadMore="loadMore" @refresh="refreshList">
			<view class="mp-count-alarmin-top" v-for="item in  tableList">
		         ......... 此处请写你自己的样式代码
			</view>
		</dragable-list>
	</view>
</template>

2. 上组件 dragable-list.vue(复制可直接用)

<script>
import UniLoadMore from "@/uni_modules/uni-load-more/components/uni-load-more/uni-load-more.vue";

/**
 * 区域滚动组件,支持上拉加载和下拉刷新。
 * 滚动区域高于页面会导致滚动异常,优先级高于页面滚动,不建议用于页面滚动。
 * */
export default {

  name: "dragable-list",
  components: {UniLoadMore},
  emits: ['refresh', 'loadMore'],
  props: {
    /**
     * 正在刷新,为 true 时重置滚动条
     * @value {boolean}
     * */
    isRefreshing: {
      type: Boolean,
      default: false
    },
    /**
     * 加载更多状态
     * @value {string} more | noMore | loading
     * */
    loadMoreStatus: {
      type: String,
      default: 'noMore'
    },
    /**
     * 刷新时候返回顶部
     * @value {boolean} true
     * */
    backTopOnRefresh: {
      type: Boolean,
      default: true
    },
  },
  data() {
    return {
      scrollTop: 0
    }
  },
  watch: {
    isRefreshing(newVal) {
      if (newVal === true && this.backTopOnRefresh) {
        this.scrollTop = 0
      }
    }
  },
  methods: {
    handleScroll(e) {
      const {scrollTop} = e.detail
      this.scrollTop = scrollTop
    },
    handleRefresh() {
      if (this.isRefreshing) return
      if (this.loadMoreStatus === 'loading') return
      this.$emit('refresh')
      this.scrollTop = 0
    },
    loadMore() {
      if (this.isRefreshing) return
      if (this.loadMoreStatus === 'more') {
        this.$emit('loadMore')
      }
    }
  },
}
</script>

<template>
  <scroll-view
      class="dragable-list"
      scroll-y
      style="height: 100%"
      refresher-background="transparent"
      :refresher-threshold="100"
      lower-threshold="0"
      :scroll-top="scrollTop"
      :refresher-triggered="isRefreshing"
      refresher-enabled
      enable-back-to-top
      show-scrollbar
      @scroll="handleScroll"
      @refresherrefresh="handleRefresh"
      @scrolltolower="loadMore"
  >
    <slot></slot>
    <uni-load-more v-if="loadMoreStatus!='noMore'" :status="loadMoreStatus" @clickLoadMore="loadMore"></uni-load-more>
  </scroll-view>
</template>

<style scoped>
.dragable-list {
    max-height: 100vh;
}
</style>
  1. 组件使用需要引入uni-ui
  2. 在这里插入图片描述
    在这里插入图片描述
  3. 搞定!
  • 8
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在 Uniapp 中,可以使用第三方组件库或者自己实现下拉上拉刷新的功能。以下是使用第三方组件库 uview-ui 实现下拉上拉刷新的步骤: 1. 安装 uview-ui:可以在项目根目录下执行以下命令进行安装: ``` npm install uview-ui ``` 2. 在 App.vue 中引入 uview-ui,并注册组件: ``` import uView from 'uview-ui'; Vue.use(uView); ``` 3. 在需要使用下拉上拉刷新的页面组件中,添加以下代码: ``` <template> <u-scroll-view ref="scrollView" :enable-back-to-top="true" @scrolltoupper="onRefresh" @scrolltolower="onLoadMore"> <!-- 页面内容 --> </u-scroll-view> </template> <script> export default { data() { return { list: [], // 数据列表 pageIndex: 1, // 当前页码 pageSize: 10, // 每页数据量 isLoading: false, // 是否正在加载数据 }; }, methods: { // 下拉刷新 onRefresh() { if (this.isLoading) { // 防止重复加载 return; } this.isLoading = true; this.pageIndex = 1; // 刷新后重置页码 // 发起数据请求 this.fetchData().then((data) => { this.list = data; this.isLoading = false; this.$refs.scrollView.finishPullDown(); // 停止下拉刷新动画 }).catch((error) => { this.isLoading = false; this.$refs.scrollView.finishPullDown(); // 停止下拉刷新动画 console.error(error); }); }, // 上拉加载更多 onLoadMore() { if (this.isLoading) { // 防止重复加载 return; } this.isLoading = true; this.pageIndex += 1; // 加载更多,页码加1 // 发起数据请求 this.fetchData().then((data) => { if (data.length > 0) { this.list = this.list.concat(data); // 合并数据 } else { this.pageIndex -= 1; // 数据为空,恢复页码 } this.isLoading = false; this.$refs.scrollView.finishPullUp(); // 停止上拉加载更多动画 }).catch((error) => { this.isLoading = false; this.$refs.scrollView.finishPullUp(); // 停止上拉加载更多动画 this.pageIndex -= 1; // 请求失败,恢复页码 console.error(error); }); }, // 发起数据请求 fetchData() { // TODO: 发起数据请求,返回 Promise 对象 }, } }; </script> ``` 在上面的代码中,使用了 u-scroll-view 组件来实现页面的滚动,并添加了 `@scrolltoupper` 和 `@scrolltolower` 事件来监听下拉上拉的操作。在 `onRefresh` 和 `onLoadMore` 函数中,分别处理了下拉刷新上拉加载更多的逻辑,并在请求数据成功或失败后,使用 `finishPullDown` 和 `finishPullUp` 方法停止下拉刷新上拉加载更多的动画。 这样就可以使用 uview-ui 实现 Uniapp 中的下拉上拉刷新了。 ### 回答2: uniapp 是一种跨平台开发框架,能够支持多个平台的应用开发,包括 App、小程序、H5 等。在 uniapp 中,我们可以通过使用组件或者自定义事件来实现页面的上拉下拉刷新功能。 上拉刷新是指在页面底部上拉时,触发某个事件或操作,例如加载更多数据或请求新的数据。在 uniapp 中,我们可以使用 `onReachBottom` 事件来实现上拉加载更多的功能。当页面滑动到底部时,就会触发 `onReachBottom` 事件,我们可以在该事件的回调函数中编写相应的逻辑,例如发送网络请求获取更多的数据,然后将数据添加到页面中。 下拉刷新是指在页面顶部下拉时,触发某个事件或操作,例如重新加载页面或获取最新的数据。在 uniapp 中,我们可以使用 `onPullDownRefresh` 事件来实现下拉刷新功能。当用户下拉页面时,就会触发 `onPullDownRefresh` 事件,我们可以在该事件的回调函数中编写相应的逻辑,例如发送网络请求获取最新的数据,然后更新页面的内容。 在使用上拉下拉刷新功能时,我们可以结合使用组件和自定义事件来实现更灵活和个性化的效果。例如,可以使用 `scroll-view` 组件作为滚动容器,然后通过监听 `scroll-view` 的滚动事件来触发上拉下拉刷新的逻辑。同时,也可以通过设置页面的样式和动画效果,来提升用户的体验。 总之,uniapp 提供了简单易用的上拉下拉刷新功能,通过合理使用组件和自定义事件,我们可以轻松实现页面的上拉加载更多和下拉刷新的效果。 ### 回答3: uniapp 是一款跨平台的开发框架,可以用于开发运行在多个平台上的应用程序。在uniapp中,提供了上拉下拉刷新的功能。 上拉刷新是指当用户将页面向上滑动到底部时,可以触发自动刷新页面的操作。在uniapp中,可以通过使用scroll-view组件实现上拉刷新的效果。我们可以将页面内容放在scroll-view组件内部,并设置其属性enableBackToTop为true,这样当用户滑动到底部时,页面会自动触发刷新操作。 下拉刷新是指当用户将页面向下拉动时,可以触发自动刷新页面的操作。在uniapp中,可以通过在页面顶部添加一个下拉刷新的组件来实现。我们可以使用uniapp提供的page-meta标签来定义页面的下拉刷新行为,设置其属性pullDownRefresh为true,然后在页面中监听下拉刷新事件,当用户进行下拉操作时,页面会自动触发刷新操作。 在实际开发中,我们可以通过监听scroll-view组件的scrolltolower事件实现上拉刷新,监听页面的pullDownRefresh事件实现下拉刷新。当触发上拉下拉刷新事件时,我们可以在相应的事件回调函数中编写刷新数据的代码,然后更新页面内容。 总的来说,uniapp提供了方便的上拉下拉刷新功能,开发者可以根据需求进行配置和使用,使得应用程序在用户交互上更加友好和流畅。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值