简单的 u-popup 弹出框

news2024/12/23 14:38:18

          uniapp中的popup组件可以用于弹出简单的提示框、操作框、菜单等。它可以通过position属性控制弹出框的位置,不同的position值会使得弹出框呈现不同的弹出形式

目录

一、实现思路

二、实现步骤

    ①view部分展示

     ②JavaScript 内容

     ③css中样式展示

三、效果展示

四、小结 + 注意事项


一、实现思路

      在需要的标签绑定了一个点击事件,点击按钮可以控制显示或隐藏uni-popup组件。

       uni-popup组件的v-model值与data中定义@close="show = false" @open="show = true" 变量绑定,

         uni-popup组件的position属性设置为"bottom",表示从底部弹出。

         uni-popup组件的show属性设置为true,表示显示遮罩层。

         uni-popup组件的animation属性设置为pop-up,表示弹出动画效果为pop-up。

        uni-popup组件中的内容可以自定义,这里是一个简单的view标签,包含一些文字和按钮。

        uni-popup组件支持拖曳的功能,默认开启拖曳的方式为长按拖动或鼠标拖动。

二、实现步骤

        ①view部分展示

<template>
	<view style="margin-top: 300rpx;">
		<view class="records">
			<view v-for="(item, index) in tabList" class="getlist" :key="index">
				<view class="flex-between" style="margin-top: 32rpx;">
					<!-- 弹出排列 -->
					<view>{{ item.cations }}</view>
					<view class="flex" @click="handleSelectCategroy(index)">
						<view class="flex">
							<view style="margin-right: 10rpx;color: #999; font-size: 32rpx;">{{ item.categoryText }}
							</view>
							<view style="margin-left: 12rpx;">
								<u-icon name="arrow-right" size="14" color="#666"></u-icon>
							</view>
						</view>
					</view>
				</view>
			</view>
		</view>
		<!-- 弹出层内容 -->
		<u-popup :show="show" mode="bottom" @close="show = false" @open="show = true" closeable="true">
			<view style="border-bottom: 1rpx solid #E5E5E5;padding:24rpx 0 32rpx; text-align: center;">选择</view>
			<view class="flex-colomn">
				<view v-for="(item, index) in arrlist" class="flex-between .ui-font" :key="index" @click="tab(item)"
					style="border-bottom: 1rpx solid #E5E5E5;padding:32rpx 24rpx; ">
					<view :class="[titleText === item.title ? 'active' : '']">{{ item.title }}</view>
					<view>
						<u-icon name="checkmark" size="15"></u-icon>
					</view>
				</view>
			</view>

		</u-popup>
	</view>
</template>

     ②JavaScript 内容

<script>
	export default {
		data() {
			return {
				//弹出层
				show: false,
				titleText: '巧克力饼干',
				arrlist: [{
					id: 1,
					title: '西红柿小面包'
				}, {
					id: 2,
					title: '其他'
				}, {
					id: 3,
					title: '其他001'
				}, {
					id: 4,
					title: '小其他'
				}, {
					id: 5,
					title: '大其他'
				}],
				tabList: [{
					cations: "选择你喜欢的面包",
					categoryText: "请选择你喜欢的"
				}, ]
			};

		},

		methods: {
			// 弹出选择值
			handleSelectCategroy(index) {
				this.show = true //当前弹出层为true
				this.curActiveCategroyIndex = index
			},

			valChange(e) {
				console.log('当前值为: ' + e.value)
			},
			tab(item) {
				this.show = false
				this.titleText = item.title
				this.tabList = this.tabList.map((it, i) => {
					if (this.curActiveCategroyIndex === i) {
						it.categoryText = this.titleText
					}
					return it
				})
			},

		}
	}
</script>

        ③css中样式展示

<style lang="scss" scoped>
	.records {
		padding: 24rpx;
		background: #FFFFFF;
		border-radius: 16rpx;
	}

	.ui-font {
		font-size: 28rpx;
		color: #333333;
		text-align: center;
		border-bottom: 1rpx solid #E5E5E5;
		padding: 28rpx 0px;
	}

	.active {
		color: #428AF6
	}
</style>

三、效果展示

                

四、小结 + 注意事项

1. u-popup组件尽量与整个的第二层位置,否则会失效

2.常用属性值:

        show【控制弹出窗口的显示与隐藏】
                类型:Boolean
                默认值:false
                。当为 true 时,弹出窗口将显示;当为 false 时,弹出窗口将隐藏。

        position 【设置弹出窗口的位置。可选值】
                类型:String
                默认值:center

                top: 弹出窗口在顶部显示。
               bottom: 弹出窗口在底部显示。
                left: 弹出窗口在左侧显示。
               right: 弹出窗口在右侧显示。
               center: 弹出窗口在屏幕中央显示。

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

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

相关文章

计算机网络:网络层上(数据平面)

文章目录 前言一、概述1.网络服务模型2.连接建立 二、路由器组成路由器结构概况输入端口的功能交换结构输出端口 三、IP&#xff08;Internet Protocol&#xff09;IPV4IPV6 四、通用转发和SDN总结 前言 网络层分两部分讲解&#xff0c;本篇文章讲解数据平面的内容&#xff1a…

Spring Boot监听redis过期的key

Redis支持过期监听&#xff0c;可以实现监听过期数据&#xff0c;实现过程如下 1、pom依赖 <!-- Redis--><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId></depend…

计算机网络(三)

&#xff08;十一&#xff09;路由算法 A、路由算法分类 动态路由和静态路由 静态路由&#xff1a;人工配制&#xff0c;路由信息更新慢&#xff0c;优先级高。这种在实际网络中要投入成本大&#xff0c;准确但是可行性弱。 动态路由&#xff1a;路由更新快&#xff0c;自动…

【MySQL】:数据类型

数据类型 一.数值类型1.整数1.tinyint2.bit类型 2.浮点类型1.float2.decimal 二.字符串类型1.char类型2.varchar类型3.char和varchar的区别4.日期和时间类型5.enum和set 三.集合查询 一.数值类型 1.整数 1.tinyint 正常插入 越界插入 如果我们向mysql特定的类型中插入不合法的…

使用BeautifulSoup 4和Pillow合并网页图片到一个PDF:一种高效的方式来处理网页图像

背景 ​ 网页上的培训材料&#xff0c;内容全是PPT页面图片。直接通过浏览器打印&#xff0c;会存在只打印第一页&#xff0c;并且把浏览器上无效信息也打印出来情况。但目标是希望将页面图片全部打印为pdf形式。 实现方案 利用网页“另存为”&#xff0c;将页面内所有图片资…

力扣题:数字与字符串间转换-12.12

力扣题-12.12 [力扣刷题攻略] Re&#xff1a;从零开始的力扣刷题生活 力扣题1&#xff1a;539. 最小时间差 解题思想&#xff1a;将字符串的时间形式换成数字形式的时间&#xff0c;然后计算差值即可&#xff0c;最重要的是最小的值加上一天的时间加入到数组最后&#xff08…

cache教程 5.分布式节点的通信

0.对原教程的一些见解 其回顾完请求流程就是抽象了两个接口&#xff0c;PeerPicker和PeerGetter。这样操作&#xff0c;读者阅读时可能很难快速明白其含义&#xff0c;不好理解为什么就创建出两个接口&#xff0c;感觉会比较疑惑。原教程的评论中也有讨论这点。 本教程就先不创…

docker mysql8 设置不区分大小写

docker安装Mysql8.0的坑之lower_case_table_names_docker mysql lower_case_table_names-CSDN博客https://blog.csdn.net/p793049488/article/details/108365929 docker run ‐di ‐‐nametensquare_mysql ‐p 33306:3306 ‐e MYSQL_ROOT_PASSWORD123456 mysql

node.js express JWT token生成与校验

目录 JWT header&#xff08;标头&#xff09; payload&#xff08;有效负载&#xff09; signature&#xff08;签名&#xff09; 访问令牌&#xff08;token&#xff09; express jwt生成、验证 生成jwt 验证jwt JWT JWT 是轻量级的数据交换格式&#xff0c;相对于传…

微服务-理论 分布式事务

一、分布式事务理论模型 分布式事务问题也叫分布式数据一致性问题&#xff0c;简单来说就是如何在分布式场景中保证多个节点数据的一致性。分布式事务产生的核心原因在于存储资源的分布性&#xff0c;比如多个数据库&#xff0c;或者MySQL和Redis两种不同存储设备的数据一致性…

R语言,table()函数实现统计每个元素出现的频数+并将最终统计频数结果转换成dataframe数据框形式

在 R中&#xff0c;要统计dataframe数据框中每个元素出现的频数&#xff0c;可以使用table()函数。以下是一个示例&#xff1a; 目录 一、创建数据 二、统计第一列每个元素出现的频数 三、统计第二列每个元素出现的频数 四、将频数结果转换为数据框&#xff0c;并改列名 一…

【OPNEGIS】Geoserver原地升级jetty,解决Apache HTTP/2拒绝服务漏洞 (CVE-2023-44487)

Geoserver是我们常用的地图服务器&#xff0c;在开源系统中的应用比较广泛。在实际环境中&#xff0c;我们可能会选用官方的二进制安装包进行部署&#xff0c;这样只要服务器上有java环境就可以运行&#xff0c;方便在现场进行部署。 1.问题来源 这次由于甲方一月一次的漏洞扫…

开源框架Apache NiFi调研

开源框架Apache NiFi调研 NiFi背景介绍一、什么是NiFi1.1 Apache NiFi特点&#xff1a;流管理、易用性、安全性、可扩展的体系结构和灵活的伸缩模型。1.2 Apache NiFi特性1.2 Apache NiFi核心概念1.3架构 二、NiFi的诞生&#xff0c;要致力于解决的问题有哪些&#xff1f;三、为…

day01、什么是数据库系统?

数据库系统介绍 1.实例化与抽象化数据库系统2.从用户角度看数据库管理系统的功能2.1 数据库定义功能2.2 数据库操纵2.3 数据库控制2.4 数据库维护功能2.5 数据库语言与高级语言 3.从系统&#xff1a;数据库管理系统应具有什么功能 来源于战德臣的B站网课 1.实例化与抽象化数据库…

React Native android环境搭建,使用夜神模拟器进行开发(适用于0.73+版本)

前言 本文基于&#xff1a;“react-native” : “^0.73.0” 1.安装 Node Node.js&#xff0c;下载时选择 > 18 版本 2.下载并安装 JDK Java SE Development Kit (JDK)&#xff0c;下载时选择 17 版本 安装 验证是否安装成功 打开命令提示符输入 javac -version 回车 3.…

【打印机如何设置只打印黑色】

目录 1. Window X 打开&#xff0c;选择“设置” 2. 选择“打印机和扫描仪” 3. 选择对应的“打印机” 4. 选择“打印首选项” 5. 选择“页设置”&#xff0c;并选择“打印选项” 6. 用于打印的墨水&#xff0c;改为“仅黑色” 7. 点击“确定”&#xff0c;关闭即可 1. Wi…

智慧储能数字孪生:能源未来的智慧引擎

随着社会对清洁能源的需求不断增加&#xff0c;智能储能技术成为能源转型的关键驱动力。在这一领域中&#xff0c;数字孪生技术的应用为智慧储能带来了全新的可能性。数字孪生是指数字化、实时、可视化的模拟系统&#xff0c;通过复制现实世界中的对象或过程&#xff0c;为智能…

基于查表法的水流量算法设计与实现

写在前面 本文分享的是一种基于查表法的水流量的算法方案设计与实现&#xff0c;算法简单易懂&#xff0c;主要面向初学者&#xff0c;有两个目的&#xff1a;一是给初学者一些算法设计的思路引导&#xff1b;二是引导初学者学习怎样用C语言编程实现。 一、设计需求 基于“19…

nodejs微信小程序+python+PHP个性化服装搭配系统APP-计算机毕业设计推荐 android

目 录 摘 要 I ABSTRACT II 目 录 II 第1章 绪论 1 1.1背景及意义 1 1.2 国内外研究概况 1 1.3 研究的内容 1 第2章 相关技术 3 2.1 nodejs简介 4 2.2 express框架介绍 6 2.4 MySQL数据库 4 第3章 系统分析 5 3.1 需求分析 5 3.2 系统可行性分析 5 3.2.1技术可行性&#xff1a;…

网络安全——SSH密码攻击实验

一、实验目的要求&#xff1a; 二、实验设备与环境&#xff1a; 三、实验原理&#xff1a; 四、实验步骤&#xff1a;​ 五、实验现象、结果记录及整理&#xff1a; 六、分析讨论与思考题解答&#xff1a; 一、实验目的要求&#xff1a; 1、了解SSH密码攻击、FTP密码攻击…