uniapp 金刚区菜单

uniapp 金刚区菜单 (含导航滑块)

html

<template>
	<!-- 菜单 -->
	<view class="menu">
		<scroll-view class="menu-scroll" scroll-x @scroll="scrollTap">
			<view class="list">
				<view class="list-row" v-for="(item,index) in formatList" :key="index">
					<view class="item" v-for="(itemc,indexc) in item" :key="indexc" @click="toPage(itemc.url)" :style="{width: width + '%'}">
						<image :src="itemc.icon" mode="widthFix" class="icon"></image>
						<view class="name">{{itemc.name}}</view>
					</view>
				</view>
			</view>
		</scroll-view>	
		<view class="progress" v-if="menusList.length > (rows * cols)">
			<view class="progress-inside" :style="{left:left}"></view>
		</view>
	</view>
</template>

js

<script>
export default {
		data() {
			return {
				menusList: [],
				formatList: [],
				rows: 2,//排列行数
				cols: 4,// 一行排列数
				showDot: true,
				width: 25, //菜单宽度 单位 %
				left: 62.5
			}
		},
		mounted() {
			this.formatMenu()
		},
		methods: {
			 scrollTap(e) {
			   let scrollLeft = e.detail.scrollLeft + 375;
			   let scrllWidth = e.detail.scrollWidth;
			   let left;
			   if (scrollLeft < 395) {
			     left = `65.625%`;
			   } else {
			     left = `${(scrollLeft / scrllWidth) * 100}%`;
			   }
			   this.left = left; 			   
			  },
			  formatMenu(){
				let that = this;
				this.width = 100 / this.cols;
				let arr = [];
				let nums = Math.ceil(this.menusList.length / this.rows) ;
				for (let i = 0; i < this.menusList.length; i += nums) {
				  arr.push(this.menusList.slice(i, i + nums));
				}
				this.formatList = arr;
			},
		}	  
}			
</script>

css

<style lang="scss" scoped>
	.menu {
		padding: 32rpx 0;
		.menu-scroll{
			width: 100%;
			background: #fff;
		}
		.list {
			// display: grid;
			// grid-template-columns: repeat(4, 1fr);
			// grid-gap: 18rpx;
			.list-row{
				white-space: nowrap;
			}
			// box-shadow: 0rpx 3rpx 6rpx rgba(0, 46, 37, 0.08);
			.item {
				// width: 100%;
				display: inline-block;
				.icon {
					display: block;
					width: 58%;
					aspect-ratio: 1 / 1;
					margin: auto;
				}

				.name {
					text-align: center;
					font-size: 24rpx;
					margin-top: 8rpx;
					padding-bottom: 12rpx;
				}
			}
		}

	}

.progress {
  position: relative;
  width: 66rpx;
  height: 8rpx;
  background: rgba(224, 224, 224, 1);
  border-radius: 4rpx;
  margin: 24rpx auto 0;
  overflow:hidden;
}

.progress-inside {
  position: absolute;
  transform: translateX(-100%);
  width: 42rpx;
  height: 8rpx;
  border-radius: 4rpx;
  background: #ff0000;
  left:62.5%; 
}

</style>
参考:https://blog.csdn.net/weixin_43957805/article/details/119145092
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Makealy

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值