uniapp滑动页面切换和下拉刷新,触底加载更多(swiper + scroll-view)

news2025/4/25 8:31:36

因为官方文档乱七八糟的,所以自己来总结下

需求:

常见的上方tag标签切换,下方是页面,上面点击切换,下面页面也切换,下方列表有下拉刷新,触底加载更多
因为这两个组件都是固定高度的,所以没办法用页面的触底,
因为有的页面不是列表,所以没办法用uniapp的下拉页面刷新生命周期
所以用uniapp的swiper轮播图来切换,轮播图固定高度,里面列表用 scroll-view来做下拉刷新和触底加载更多

效果图
效果图2

代码:

开头有用到uviewUI框架的u-navbar头部,不需要的可以自己删了

<template>
	<view class="pastureWater">
		<u-navbar title="牧场用水管理" bgColor="#4f9a47" :placeholder="true" />
		<view class="tagList">
			<view class="item" v-for="(item, index) in tagList" :key="index" :class="{active: tagActive === index}"
				@click="tagActive = index">
				<text>{{item}}</text>
			</view>
		</view>
		<view class="swiperBox">
			<swiper class="swiper" :current="tagActive" @change="swiperChange">
				<swiper-item class="swiperItem">
					<view class="search">
						<view class="formItem">
							<text>监管类型:</text>
							<text>生活区</text>
						</view>
						<view class="formItem">
							<text>牛舍:</text>
							<text>1-1</text>
						</view>
					</view>
					<div class="listBox">
						<scroll-view class="list" scroll-y="true" :lower-threshold="0" :throttle="false"
							:refresher-enabled="true" :refresher-triggered="triggered" refresher-background="#f8f4f3"
							@refresherrefresh="refresherrefresh" @scrolltolower="scrolltolower">
							<view class="item" v-for="(item, index) in 2" :key="index">
								<view class="itemList">
									<view class="cell">
										<text>设备编号:232436020043</text>
									</view>
									<view class="cell">
										<text>设备名称:1号牛舍电表</text>
									</view>
									<view class="cell">
										<text>当前总电能:8320.4</text>
									</view>
									<view class="cell">
										<text>时间:2024-01-09 12:12:12</text>
									</view>
									<view class="cell">
										<text>在线状态:在线</text>
									</view>
								</view>
							</view>
						</scroll-view>
					</div>
				</swiper-item>
				<swiper-item class="swiperItem">
					<view>数据分析</view>
				</swiper-item>
				<swiper-item class="swiperItem">
					<view>历史数据</view>
				</swiper-item>
			</swiper>
		</view>
	</view>
</template>

<script>
	export default {
		data() {
			return {
				tagList: ['用水设备', '数据分析', '历史数据'],
				tagActive: 0,
				triggered: false,
				deviceList: [],
				historicalDataList: [],
			}
		},
		onLoad() {},
		methods: {
			scroll(item) {
				console.log(item);
			},
			swiperChange(info) {
				this.tagActive = info.target.current
			},
			// 触底加载更多
			scrolltolower() {
				console.log('触底加载更多');
			},
			// 下拉刷新
			refresherrefresh() {
				console.log('下拉刷新');
				this.triggered = true;
				setTimeout(() => {
					this.triggered = false;
				}, 3000)
			},
		}
	}
</script>

<style lang="scss" scoped>
	.pastureWater {
		height: 100vh;
		display: flex;
		flex-direction: column;
		background-color: #f8f4f3;

		/deep/ uni-text.u-icon__icon.uicon-arrow-left {
			color: #fff !important;
		}

		/deep/ .u-line-1.u-navbar__content__title {
			color: #fff;
		}

		.tagList {
			display: flex;
			height: 80rpx;
			background-color: #fff;
			margin-bottom: 16rpx;

			.item {
				width: 100%;
				height: 100%;
				display: flex;
				justify-content: center;
				align-items: center;
				border-bottom: 4rpx solid transparent;

				&.active {
					color: #9dbc67;
					border-bottom: 4rpx solid #9dbc67;
				}
			}
		}

		.swiperBox {
			flex: 1;
			display: flex;
			flex-direction: column;

			.swiper {
				height: 100%;

				.swiperItem {
					height: 100%;
					display: flex;
					flex-direction: column;
					padding: 0 20rpx;

					.search {
						display: flex;

						.formItem {
							height: 76rpx;
							width: 50%;
							display: flex;
							align-items: center;
							padding: 0 20rpx;

							text {
								display: flex;
								align-items: center;
								justify-content: center;
								padding: 0 10rpx;
								height: 60rpx;
								line-height: 1.05;
								font-size: 28rpx;

								&:last-child {
									flex: 1;
									background-color: #fff;
									border-radius: 5rpx;
								}
							}
						}
					}

					.listBox {
						height: calc(100% - 76rpx);

						.list {
							height: 100%;

							.item {
								margin-bottom: 16rpx;
								border-radius: 10rpx;
								padding: 20rpx 20rpx 10rpx;
								background-color: #fff;

								&:last-child {
									margin-bottom: 0;
								}

								.itemList {
									display: flex;
									flex-wrap: wrap;

									.cell {
										width: 50%;
										font-size: 24rpx;
										color: #000;
										margin-bottom: 10rpx;
									}
								}
							}
						}
					}
				}
			}
		}
	}
</style>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1382175.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java swing UI第三方设计器JFormDesiner和FlatLaf UI

安装JFormDesiner 官网&#xff1a;https://www.formdev.com/ 先去IDEA的插件市场安装吧 JFormDesiner是非开源&#xff0c;且付费的插件&#xff0c;可以自己去找找不付费的使用方法。在swing可视化设计UI非常高效快捷&#xff0c;初学者可能需要一定时间探索&#xff0c;熟…

高性能RPC框架解密

专栏集锦&#xff0c;大佬们可以收藏以备不时之需&#xff1a; Spring Cloud 专栏&#xff1a;http://t.csdnimg.cn/WDmJ9 Python 专栏&#xff1a;http://t.csdnimg.cn/hMwPR Redis 专栏&#xff1a;http://t.csdnimg.cn/Qq0Xc TensorFlow 专栏&#xff1a;http://t.csdni…

【数据结构】串,数组,广义表 | 笔记整理 | C/C++实现

文章目录 前言一、串1.1、串的定义1.2、案例引入1.3、串的类型定义和存储结构1.4、串的模式匹配算法1.4.1、BF算法1.4.2、KMP算法 二、数组2.1、数组的定义2.2、数组的抽象数据类型定义2.3、数组的顺序存储2.4、特殊矩阵的压缩存储 三、广义表四、病毒案例 前言 参考视频&…

大模型实战营Day4 作业

基础作业&#xff1a; 构建数据集&#xff0c;使用 XTuner 微调 InternLM-Chat-7B 模型, 让模型学习到它是你的智能小助手&#xff0c;效果如下图所示&#xff0c;本作业训练出来的模型的输出需要将不要葱姜蒜大佬替换成自己名字或昵称&#xff01; 微调前&#xff08;回答比较…

CF1178F1 Short Colorful Strip 题解

Short Colorful Strip 传送门 题面翻译 题目描述 这是F题的第一个子任务。F1和F2的区别仅在对于m和时间的限制上 有n1种颜色标号从0到n&#xff0c;我们有一条全部染成颜色0的长为m的纸带。 Alice拿着刷子通过以下的过程来给纸带染色&#xff1a; 我们按照从1到n的顺序进…

redis夯实之路-主从复制详解

Redis中可以通过执行slaveof命令或者设置slaveof选项&#xff0c;让一个服务器区复制另一个服务器&#xff0c;被复制的为主服务器&#xff0c;复制的为从服务器。 复制 Redis中可以通过执行slaveof命令或者设置slaveof选项&#xff0c;让一个服务器区复制另一个服务器&#…

科大讯飞星火大模型接入API js 部分 接口 安装注意事项

下载以下链接例子运行程序 https://xfyun-doc.xfyun.cn/static%2F16968175055332330%2Fspark_js_demo.zip 官网给的说明 准备 1.在demo中填写APPID、APISecret、APIKey&#xff0c;可到控制台-我的应用-大模型页面获取 2.安装nodejs 本地运行 1.打开cmd&#xff0c;进入dem…

2024三掌柜赠书活动第三期:Rust系统编程

目录 前言 Rust语言概念 关于《Rust系统编程》 Rust系统编程的核心点 Rust系统编程的关键技术和工具 编辑推荐 内容简介 作者简介 图书目录 书中前言/序言 《Rust系统编程》全书速览 结束语 前言 在技术圈&#xff0c;最近的编程语言新秀当属Rust莫属&#xff0c;R…

Center审计策略表安装和策略添加(事务)——(Linux/Windows版本)

本博客主要讲述Center的审计策略表安装和策略添加 使用事务添加 1、开启事务 my->StartTransaction(); 2、编写sql语句 //清除原来数据&#xff0c;防止数据污染my->Query("DROP TABLE IF EXISTS t_strategy");string sql "CREATE TABLE t_strategy (…

虚幻引擎nDisplay教程:如何同步nDisplay节点与Switchboard + Helix Core

对于使用大型LED屏幕进行拍摄的虚拟制作团队来说&#xff0c;虚幻&#xff08;Unreal&#xff09;的nDisplay是一个重要的工具。但是&#xff0c;在nDisplay中将正确版本的文件发送到每个节点会非常耗时。立即阅读本文&#xff0c;您将了解到如何使用Perforce Helix Core版本控…

Jenkins集成Sonar Qube

下载插件 重启Jenkins 容器 sonarqube 使用令牌 Jenkins 配置 重新构建

Flask类视图的基本用法及高级技巧详解

概要 当我们谈论Web开发时&#xff0c;Flask是Python世界中最受欢迎的微框架之一。简洁灵活的设计让它在开发小型到中型的Web应用程序时尤其受欢迎。在Flask中处理URL路由时&#xff0c;我们常常会使用基于函数的视图。尽管这很简单直接&#xff0c;但是随着应用的增长&#x…

Linux驱动学习—I2C总线

1、应用层实现I2C通信 1.1 I2C简介 I2C是很常见的一种总线协议&#xff0c;I2C是NXP公司设计的&#xff0c;I2C使用两条线在主控制器和从机之间进行数据通信。一条是SCL&#xff08;串行时钟线&#xff09;&#xff0c;另外一条是SDA(串行数据线)&#xff0c;因为I2C这两条数…

如何使用创建时间给文件重命名,简单的批量操作教程

在处理大量文件时&#xff0c;有时要按照规则对文件重命名&#xff0c;根据文件的创建时间来重命名。那如何批量操作呢&#xff1f;现在一起来看云炫文件管理器如何用文件的创建时间来批量重命名。 按创建时间重命名文件的前后对比图。 用创建时间批量给文件重命名的步骤&…

定时器问题(vue的问题)

我在a页面写一个定时&#xff0c;让他每秒钟打印一个1&#xff0c;然后跳转到b页面&#xff0c;此时可以看到&#xff0c;定时器依然在执行。这样是非常消耗性能的。如下图所示&#xff1a; 解决方法1 首先我在data函数里面进行定义定时器名称&#xff1a; data() {return {t…

六、新建窗体时,几种窗体的区别

新建窗体时&#xff0c;会有几种类型的选项&#xff0c;很多同学不明白其中的意思&#xff0c;我们在本章节中详细介绍一下几种窗体的区别。 窗体的类型分以下几种 Dialog with Buttons Bottom 带按钮的对话框&#xff0c;按钮在底部 Dialog with Buttons Right 带按钮的对话框…

【Java SE语法篇】8.面向对象三大特征——封装、继承和多态

&#x1f4da;博客主页&#xff1a;爱敲代码的小杨. ✨专栏&#xff1a;《Java SE语法》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ 文章目录 1. 封装1.1 封装的概念1.2 为什么封装1.3 封装的实现…

Vue基知识四

本文对前边几章所学习的内容&#xff0c;以案例的形式做一个总结 一 TodoList案例 即待办事项案例&#xff0c;效果如下 1.1 组件化编码流程&#xff08;通用&#xff09; 这是编码时的通用流程&#xff0c;以后也可以按照这个流程来写代码&#xff08;熟悉后这个流程的顺…

Flutter开发进阶之动画

Flutter开发进阶之动画 在Flutter中&#xff0c;动画是至关重要的一个部分&#xff0c;它能够为应用程序提供更加丰富和生动的用户体验&#xff0c;Flutter中的动画系统是UI框架的核心功能之一&#xff0c;也是开发者学习Flutter框架的重要部分&#xff0c;由于动画原理在所有…

Python基本语法与变量的相关介绍

python基本语法与变量 python语句的缩进 Python代码块使用缩进对齐表示代码逻辑&#xff0c;Python每段代码块缩进的空白数量可以任意&#xff0c;但要确保同段代码块语句必须包含相同的缩进空白数量。建议在代码块的每个缩进层次使用单个制表符或两个空格或四个空格 , 切记不…