我的编程空间,编程开发者的网络收藏夹
学习永远不晚

小程序开发实战指南之封装自定义弹窗组件

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

小程序开发实战指南之封装自定义弹窗组件

1、探讨需求封装popup自定义弹窗组件

首先我们需要探讨一下,封装自定义的组件都需要什么功能

  • 需要一个半透明灰色的背景,用于区分与非弹窗内容,点击灰色区域也可以关闭弹窗。
  • 需要一个关闭按钮和两个操作按钮,一个确定,一个取消。
  • 弹窗内容:标题,内容区域,因为是自定义所以都使用了具名插槽,也可以设置默认的显示内容。
  • 弹窗的显示位置,本次封装只考虑了居中与页面底部两个常用显示位置。

2、实战开发弹窗组件

2.1 子组件内容 popup.vue文件

<template>
	<view class="mark" v-if="isShow" @click="close">
		<view :class="bottom?'bottom':'center'" class="content" >
			<view @click="close">
				<image class="close" class="lazy" data-src="../static/close.png" ></image>
			</view>
			<slot name="title">
				<view class="title">子组件默认标题</view>
			</slot>
			<slot name="body">
				<text style="font-size: 14px;">确定要取消订单吗?取消之后购物车也将清空。</text>
			</slot>
			<slot name="bottom">
				<view class="btns">
					<view class="confirm btn" @click="confirm">确定</view>
					<view class="cancel btn" @click="cancel">取消</view>
				</view>
			</slot>
		</view>
	</view>
</template>

<script>
	export default {
		props: {
			isShow: {
				type: Boolean,
				default: false
			},
			// 子组件接收一个布尔类型的bottom,如果为true则弹窗则在页面的底部,false为默认居中显示
			bottom: {
				type: Boolean,
				default: false
			}
		},
		data() {
			return{
			}
		},
		methods: {
			close(){
				this.$emit('close')
			},
			cancel(){
				this.$emit('cancel')
			},
			confirm(){
				this.$emit('confirm')
			},
		}
	}
</script>

<style lang="scss">
	.mark {
		position: fixed;
		width: 100vw;
		height: 100vh;
		background-color: rgba(0, 0, 0, 0.3);
		left: 0;
		bottom: 0;
		top: 0;
		right: 0;
		display: flex;
		justify-content: center;
		align-items: center;
	}
	.bottom{
		position: absolute;
		bottom: 0 ;
		width: 100vw;
	}
	.center{
		width: 80vw;
		position: relative;
	}
	.content{
		background-color: #fff;
		border-radius: 20rpx;
		height: 400rpx;
		
		padding: 40rpx;
		box-sizing: border-box;
		
		.close{
			position:absolute;
			right:30rpx;
			top: 20rpx;
			width: 40rpx;
			height: 40rpx;
		}
		.title{
			text-align: center;
			font-weight: 600;
			height: 50rpx;
			line-height: 50rpx;
			margin-bottom: 20rpx;
		}
		.btns{
			bottom: 20px;
			position: absolute;
			display: flex;
			justify-content: space-between;
			width: 88%;
			.btn{
				width: 160rpx;
				height: 80rpx;
				text-align: center;
				line-height: 80rpx;
				border-radius: 20rpx;
			}
			.confirm{
				background: bisque;
			}
			.cancel{
				background: #ccc;
			}
		}
		
	}
</style>

注意:

本文CSS内容使用了scss语法,不使用的话可以将嵌套的样式拿出即可。

解释说明:

  • isShow 用于控制弹出层的显示与隐藏,在点击灰色空白区域和右上角关闭按钮,还有确定按钮与取消按钮之后都会关闭弹出层。
  • bottom 用于控制弹出层的显示位置,默认为居中显示
  • methods中向父组件传递了三个方法,分别是关闭弹窗,点击确定按钮,点击取消按钮
  • 使用具名插槽,在父组件中可以自定义插槽中的内容,方便不同位置的弹窗显示样式

2.2 父组件引用子组件

<template>
	<view class="container">
		<view class="btn" @click="open">
			显示弹出层
		</view>	
		<popup :isShow='visible' :bottom='true'  @close="closeMadle" @cancel="cancel" @confirm="confirm">
			<template v-slot:title>
				<view class="title">
					父组件自定义标题
				</view>
			</template>
			<template v-slot:body>
				<view class="body" >
					这里是父组件引用子组件,使用具名插槽编写的自定义内容和样式。
				</view>
			</template>
		</popup>
	</view>
	
</template>

<script>
	import popup from '../../components/popup.vue'
	export default {
		components: {
			popup
		},
		data() {
			return {
				visible:false,
			}
		},
		methods: {
			open(){
				this.visible = true
				uni.hideTabBar()
			},
			closeMadle(){
				this.visible = false
				uni.showTabBar()
			},
			confirm(){
				// 这里调用接口执行点击确定后的操作并关闭弹窗
				console.log('点击了确认按钮')
				this.visible = false
			},
			cancel(){
				// 点击了取消按钮直接关闭弹窗
				console.log('点击了取消按钮')
				this.visible = false
			},
		}
	}
</script>

<style lang="scss>
	.title{
		text-align: center;
		font-weight: 600;
		height: 50rpx;
		line-height: 50rpx;
		margin-bottom: 20rpx;
	}
	.body{
		font-size: 14px;
		font-weight: 600;
		color: darkorchid;
	}
</style>

注意:

  • 本文CSS内容使用了scss语法,不使用的话可以将嵌套的样式拿出即可。

解释说明:

  • 引用子组件,并在conponents中注册。
  • bottom 为true用于控制弹出层的弹窗在底部显示,不传默认为居中显示。
  • @语法接收子组件中向父组件传递的三个方法,在父组件methods中定义三个方法做相应的操作。
  • 使用具名插槽,自定义插槽中的内容。
  • uni.showTabBar() 和 uni.hideTabBar()两个方法用于控制原生tabbar的显示与隐藏。

3、效果图预览

3.1 不使用具名插槽的原有样式效果

3.2 使用具名插槽之后样式效果

这里是演示的那个显示在页面底部的弹窗,如果不需要直接将代码片段里的:bottom="true"删掉即可

总结

到此这篇关于小程序开发实战指南之封装自定义弹窗组件的文章就介绍到这了,更多相关小程序封装自定义弹窗组件内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

小程序开发实战指南之封装自定义弹窗组件

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

小程序开发实战指南之封装自定义弹窗组件

最近在做公司的小程序项目,发现设计上有很多不统一,代码上有很多冗余,下面这篇文章主要给大家介绍了关于小程序开发实战指南之封装自定义弹窗组件的相关资料,需要的朋友可以参考下
2022-11-13

uniapp小程序开发组件封装之自定义轮播图效果

这篇文章主要介绍了uniapp小程序开发组件封装之自定义轮播图,本文主要展示小程序端封装轮播图组件,使用的是uniapp进行的开发,主要使用的是uniapp官网提供的swiper组件,需要的朋友可以参考下
2023-02-06

微信小程序如何实现自定义弹窗组件

本篇内容主要讲解“微信小程序如何实现自定义弹窗组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“微信小程序如何实现自定义弹窗组件”吧!首先,放一下,最终的效果图:这是我们最后要实现的效果那么,首
2023-07-02

编程热搜

目录