vue+html中利用hover制作三级菜单

效果

展示

参考

https://blog.csdn.net/futianwenA/article/details/83999129

<!DOCTYPE html>
<html lang="zh">
	<head>
		<meta charset="UTF-8" />
		<meta name="viewport" content="width=device-width, initial-scale=1.0" />
		<meta http-equiv="X-UA-Compatible" content="ie=edge" />
		<script src="js/vue.js" type="text/javascript" charset="utf-8"></script>
		<title>Document</title>
		<style type="text/css">
			* {
				margin: 0;
				padding: 0;
			}

			#div-nav {
				width: 100%;
				height: 70px;
				
			}

			/*一级菜单*/
			.menu-1 {
				width: 140px;
				height: 70px;
				background: lightgray;
				box-shadow: 2px 0px 5px black;
				margin-left: 30px;
				text-align: center;
				line-height: 70px;
				font-size: 20px;
			}

			.menu-1:hover {
				background: dimgray;
			}

			/*二级菜单*/
			.menu2-all {
				margin-left: 140px;
				display: none;
				margin-top: -70px;
			}

			.menu-2 {
				width: 140px;
				height: 70px;
				background: lightgray;
				box-shadow: 2px 0px 5px black;
				text-align: center;
				line-height: 70px;
				font-size: 20px;
			}

			.menu-2:hover {
				background: dimgray;
			}

			/*三级菜单*/
			.menu3-all {
				position: relative;
				left: 140px;
				top: -70px;
				display: none;
			}

			.menu-3 {
				width: 140px;
				height: 70px;
				background: lightgray;
				box-shadow: 2px 0px 5px black;
				text-align: center;
				line-height: 70px;
				font-size: 20px;
			}

			.menu-1:hover .menu2-all {
				display: block;
			}

			.menu-2:hover .menu3-all {
				display: block;
			}

			.menu-3:hover {
				background: dimgray;
			}
		</style>
	</head>
	<body>
		<div id="app">
			<div id="div-nav" v-for="(item,index) in nav.data">				
				<div class="menu-1" id="div-user">
					{{item.name}}
					<div class="menu2-all">
						<div class="menu-2" id="div-write" v-for="(item2,index2) in item.second">
							{{item2.name}}
							<div class="menu3-all">
								<div class="menu-3" v-for="(item3,index3) in item2.third">{{item3.name}}</div>
							</div>
						</div>
					</div>

				</div>

			</div>
		</div>

	</body>

	<script>
		var app = new Vue({
			el: '#app',
			data: {
				message: 'Hello Vue!',
				//前后端分离,推荐后端返回给前端数据格式
				//前后端分离,推荐后端返回给前端数据格式
				nav: {
					"status": 0, //执行状态码
					"msg": "SUCCESS", //说明文字信息,没有为NULL
					"data": [{ //对象中嵌套数组,数组是返回的数据,
						"id": 1,
						"name": "一级菜单",
						"second": [{
							"id": 11,
							"name": "二级菜单",
							"third": [{
								"id": 111,
								"name": "三级菜单1",
							},
							{
								"id": 112,
								"name": "三级菜单2",
							},
							{
								"id": 113,
								"name": "三级菜单3",
							}
							]
						}]
					}, {
						"id": 2,
						"name": "一级菜单2",
						"second": [{
							"id": 11,
							"name": "二级菜单2",
							"third": [{
								"id": 111,
								"name": "三级菜单4",
							},
							{
								"id": 112,
								"name": "三级菜单5",
							},
							
							]
						},
						{
							"id": 113,
							"name": "二级菜单3",
						}
						]
					}]
				},


				message2: 'Hello Vue!',
			},
			components: {
				
			},
			methods: {
				back: function() {
					this.$router.back(-1);
				}
			}
		})
	</script>
</html>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您可以使用Vue.js与TypeScript结合Element Plus来实现省市区三级联动。以下是一个简单示例: 首先,安装Element Plus和相应的类型声明文件: ```bash npm install element-plus npm install @types/element-plus ``` 然后,创建一个Vue组件,并在其使用Element Plus的Cascader组件: ```vue <template> <div> <el-cascader v-model="selectedValues" :options="options" :props="props" @change="handleChange" ></el-cascader> </div> </template> <script lang="ts"> import { defineComponent } from 'vue'; import { Cascader, CascaderOption } from 'element-plus'; export default defineComponent({ name: 'AddressCascader', components: { [Cascader.name]: Cascader, }, data() { return { selectedValues: [], options: [ { value: '北京', label: '北京', children: [ { value: '东城区', label: '东城区', children: [ { value: '安定门', label: '安定门', }, { value: '建国门', label: '建国门', }, ], }, // 其他区... ], }, // 其他省份... ], props: { value: 'value', label: 'label', children: 'children', }, }; }, methods: { handleChange(value: string[]) { // 处理选择的值 console.log(value); }, }, }); </script> ``` 在这个示例,我们使用了Element Plus的Cascader组件来实现省市区三级联动。通过绑定`v-model`指令,我们可以获取用户选择的值,并在`handleChange`方法进行处理。 请注意,示例的数据是静态的,您可以根据实际情况进行修改,例如从后端获取数据并动态生成选项。 希望这个示例能够帮助您实现省市区三级联动!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值