| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | <template> | 
					
						
							|  |  |  | 	<view class="tabbar-container"> | 
					
						
							|  |  |  | 		<!-- :style="['width: calc(100% /' + tabbar.length + ')']" --> | 
					
						
							|  |  |  | 		<view class="tabbar-item" :class="[item.centerItem ? ' center-item' : '']" v-for="(item, i) in tabbar" :key="i" | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 			@click="goPage(item)" v-if="'01'==nowUserType ||('02'==nowUserType && 'fabu'!=item.code)"> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			<view class="item-top"> | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 				<view style="position: relative;margin: auto;"> | 
					
						
							| 
									
										
										
										
											2025-03-31 15:40:40 +08:00
										 |  |  | 					<image class="dl-image" :src="menuCode === item.code ? item.selectedIconPath : item.iconPath" /> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 					<image v-if="1==i" class="dl-vip" src="@/static/index/vip.png" mode="aspectFit"></image> | 
					
						
							|  |  |  | 				</view> | 
					
						
							|  |  |  | 			</view> | 
					
						
							| 
									
										
										
										
											2025-03-31 15:40:40 +08:00
										 |  |  | 			<view class="item-bottom" :class="[menuCode === item.code ? 'item-active' : '']">{{ item.text }}</view> | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 		</view> | 
					
						
							|  |  |  | 	</view> | 
					
						
							|  |  |  | </template> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <script> | 
					
						
							|  |  |  | 	export default { | 
					
						
							| 
									
										
										
										
											2025-03-31 14:31:41 +08:00
										 |  |  | 		props: { | 
					
						
							| 
									
										
										
										
											2025-03-31 15:40:40 +08:00
										 |  |  | 			menuCode: { | 
					
						
							|  |  |  | 				Type: 'String', | 
					
						
							|  |  |  | 				default: 'home' | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 			}, | 
					
						
							|  |  |  | 			nowUserType: { | 
					
						
							|  |  |  | 				Type: 'String', | 
					
						
							|  |  |  | 				default: '' | 
					
						
							| 
									
										
										
										
											2025-03-31 14:31:41 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 		data() { | 
					
						
							|  |  |  | 			return { | 
					
						
							|  |  |  | 				tabbar: [{ | 
					
						
							|  |  |  | 						id: 0, | 
					
						
							|  |  |  | 						code: "home", | 
					
						
							|  |  |  | 						text: "首页", | 
					
						
							|  |  |  | 						iconPath: '/static/images/tabbar/home.png', | 
					
						
							|  |  |  | 						selectedIconPath: '/static/images/tabbar/home_.png', | 
					
						
							|  |  |  | 						centerItem: false | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						id: 1, | 
					
						
							|  |  |  | 						code: "dingyue", | 
					
						
							|  |  |  | 						text: "订阅", | 
					
						
							|  |  |  | 						iconPath: '/static/images/tabbar/dingyue.png', | 
					
						
							|  |  |  | 						selectedIconPath: '/static/images/tabbar/dingyue_.png', | 
					
						
							|  |  |  | 						centerItem: false | 
					
						
							|  |  |  | 					}, | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 					{ | 
					
						
							|  |  |  | 						id: 4, | 
					
						
							|  |  |  | 						code: "fabu", | 
					
						
							|  |  |  | 						text: "发布", | 
					
						
							|  |  |  | 						iconPath: '/static/images/tabbar/new_notice.png', | 
					
						
							|  |  |  | 						selectedIconPath: '/static/images/tabbar/new_notice.png', | 
					
						
							|  |  |  | 						centerItem: true | 
					
						
							|  |  |  | 					}, | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 					{ | 
					
						
							|  |  |  | 						id: 2, | 
					
						
							|  |  |  | 						code: "myNotice", | 
					
						
							|  |  |  | 						text: "我的通告", | 
					
						
							|  |  |  | 						iconPath: '/static/images/tabbar/my_notice.png', | 
					
						
							|  |  |  | 						selectedIconPath: '/static/images/tabbar/my_notice_.png', | 
					
						
							|  |  |  | 						centerItem: false | 
					
						
							|  |  |  | 					}, | 
					
						
							|  |  |  | 					{ | 
					
						
							|  |  |  | 						id: 3, | 
					
						
							|  |  |  | 						code: "my", | 
					
						
							|  |  |  | 						text: "我的", | 
					
						
							|  |  |  | 						iconPath: '/static/images/tabbar/my.png', | 
					
						
							|  |  |  | 						selectedIconPath: '/static/images/tabbar/my_.png', | 
					
						
							|  |  |  | 						centerItem: false | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				] | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		onLoad() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		onUnload() { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		}, | 
					
						
							|  |  |  | 		methods: { | 
					
						
							|  |  |  | 			/** | 
					
						
							|  |  |  | 			 * 页面跳转 | 
					
						
							|  |  |  | 			 * @param {Object} item | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			goPage(item) { | 
					
						
							|  |  |  | 				this.$emit("changeMenu", item.code) | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | <style scoped lang="scss"> | 
					
						
							|  |  |  | 	$textDefaultColor: #9B9B9B; // 文字默认颜色
 | 
					
						
							|  |  |  | 	$textSelectedColor: #FC1F3E; // 文字选中颜色
 | 
					
						
							|  |  |  | 	$centerItemBg: #fff; // 中间凸起按钮背景
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.tabbar-container { | 
					
						
							|  |  |  | 		bottom: 0; | 
					
						
							|  |  |  | 		position: fixed; | 
					
						
							|  |  |  | 		left: 0; | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		width: 100%; | 
					
						
							|  |  |  | 		height: 125rpx; | 
					
						
							|  |  |  | 		color: $textDefaultColor; | 
					
						
							|  |  |  | 		background-color: #F7F7F7; | 
					
						
							|  |  |  | 		background-size: 100% 100%; | 
					
						
							| 
									
										
										
										
											2025-03-31 15:40:40 +08:00
										 |  |  | 		box-shadow: 0 -3px 3px -3px rgba(0, 0, 0, 0.3); | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.tabbar-item { | 
					
						
							|  |  |  | 		display: flex; | 
					
						
							|  |  |  | 		flex-direction: column; | 
					
						
							|  |  |  | 		justify-content: center; | 
					
						
							|  |  |  | 		align-items: center; | 
					
						
							|  |  |  | 		text-align: center; | 
					
						
							|  |  |  | 		width: 150rpx; | 
					
						
							|  |  |  | 		height: 120rpx; | 
					
						
							|  |  |  | 		flex-grow: 1; | 
					
						
							|  |  |  | 		position: relative; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.item-top { | 
					
						
							| 
									
										
										
										
											2025-04-24 10:20:03 +08:00
										 |  |  | 			padding-top: 13rpx; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			flex-shrink: 0; | 
					
						
							|  |  |  | 			width: 150rpx; | 
					
						
							|  |  |  | 			height: 130rpx; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			.dl-image { | 
					
						
							| 
									
										
										
										
											2025-04-24 10:20:03 +08:00
										 |  |  | 				height: 53rpx; | 
					
						
							|  |  |  | 				width: 53rpx; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			.dl-vip { | 
					
						
							|  |  |  | 				position: absolute; | 
					
						
							| 
									
										
										
										
											2025-04-24 10:20:03 +08:00
										 |  |  | 				height: 20rpx; | 
					
						
							|  |  |  | 				top: 0rpx; | 
					
						
							|  |  |  | 				right: -21px; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.item-bottom { | 
					
						
							|  |  |  | 			width: 100%; | 
					
						
							| 
									
										
										
										
											2025-04-24 10:20:03 +08:00
										 |  |  | 			font-size: 26rpx; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			position: absolute; | 
					
						
							| 
									
										
										
										
											2025-04-24 10:20:03 +08:00
										 |  |  | 			bottom: 30rpx; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.item-active { | 
					
						
							|  |  |  | 			color: $textSelectedColor; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	.center-item { | 
					
						
							|  |  |  | 		position: relative; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.item-top { | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 			padding-top: 0rpx !important; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 			position: absolute; | 
					
						
							|  |  |  | 			top: -55rpx; | 
					
						
							|  |  |  | 			left: 50%; | 
					
						
							|  |  |  | 			transform: translateX(-50%); | 
					
						
							|  |  |  | 			width: 105rpx; | 
					
						
							|  |  |  | 			height: 105rpx; | 
					
						
							|  |  |  | 			background-color: $centerItemBg; | 
					
						
							|  |  |  | 			border-radius: 50%; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		.item-bottom { | 
					
						
							|  |  |  | 			position: absolute; | 
					
						
							| 
									
										
										
										
											2025-04-11 15:08:25 +08:00
										 |  |  | 			bottom: 20rpx; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		image { | 
					
						
							|  |  |  | 			width: 105rpx !important; | 
					
						
							|  |  |  | 			height: 105rpx !important; | 
					
						
							| 
									
										
										
										
											2025-03-21 17:57:53 +08:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | </style> |