vue高亮一级、二级导航
使用vue开发过程中有的项目会存在多级导航的情况,如下图,这种就存在了两层,那么该如何高亮一级导航,又该如何高亮二级导航这就是今天我要记录的内容。

1、高亮一级导航很简单,代码如下:
// 点击一级导航
changeFirstLevel(index,e) {
this.secondIndexCur = -1;
this.firstIndexCur = index;
}
2、高亮二级导航,代码如下:
// view部分
<ul class="firstLevelNav">
<li v-for="(item, index) in customNav" :key="index">
<router-link :to="item.pathUrl">
<div :class="{'cur': firstIndexCur == index}" @click="changeFirstLevel(index, $event)">{{item.name}}</div>
</router-link>
<ul class="secondLevelNav">
<li v-for="(sonItem, sonIndex) in item.secondLevelNavList" :key="sonIndex">
<router-link :to="sonItem.pathUrl">
<div :class="[secondIndexCur == index + ',' + sonIndex ? 'cur' : '']" @click="changeSecondLevel(index, sonIndex, $event)">{{sonItem.name}}</div>
</router-link>
</li>
</ul>
</li>
</ul> // 点击二级导航
changeSecondLevel(index, sonIndex, e) {
this.firstIndexCur = -1;
this.secondIndexCur = index + ',' + sonIndex;
}
(注意:为什么在<router-link></router-link>中又写了一个div呢,是因为我在完成代码后点击导航高亮样式并不能成功添加,开始我是直接把class添加到了rouer-link上)
以下是导航组件的全部代码:
<template>
<!-- 自定义报表 - 左侧导航 -->
<div class="customNav">
<div class="pic">
<img src="./images/pic.png" alt="">
</div>
<ul class="firstLevelNav">
<li v-for="(item, index) in customNav" :key="index">
<router-link :to="item.pathUrl">
<div :class="{'cur': firstIndexCur == index}" @click="changeFirstLevel(index, $event)">{{item.name}}</div>
</router-link>
<ul class="secondLevelNav">
<li v-for="(sonItem, sonIndex) in item.secondLevelNavList" :key="sonIndex">
<router-link :to="sonItem.pathUrl">
<div :class="[secondIndexCur == index + ',' + sonIndex ? 'cur' : '']" @click="changeSecondLevel(index, sonIndex, $event)">{{sonItem.name}}</div>
</router-link>
</li>
</ul>
</li>
</ul>
</div>
</template> <script>
export default {
data() {
return {
firstIndexCur: -1, // 一级导航添加类名元素
secondIndexCur: -1, // 一级导航添加类名元素
customNav: [{
name: '数据源',
pathUrl: '/dataSource',
secondLevelNavList: [{
name: '新建',
pathUrl: '/newlyBuild/addData'
}]
},{
name: '配置SQL',
pathUrl: '/configSQL',
secondLevelNavList: [{
name: '新建',
pathUrl: '/configNewlyBuild/addData'
}]
},{
name: '业务SQL',
pathUrl: '/businessSQL',
secondLevelNavList: []
}],
pathName: ''
}
},
mounted() {
this.pathName = this.$router.history.current.path;
this.pathName = this.pathName === '/' ? '/dataSource' : this.pathName; // 默认路由
this.highLightLeftNav();
},
watch: {
// 监听 url 的变化
$route(to, from) {
this.pathName = to.path;
this.highLightLeftNav();
}
},
methods: {
// 点击一级导航
changeFirstLevel(index,e) {
this.secondIndexCur = -1;
this.firstIndexCur = index;
},
// 点击二级导航
changeSecondLevel(index, sonIndex, e) {
this.firstIndexCur = -1;
this.secondIndexCur = index + ',' + sonIndex;
},
// 刷新页面时根据url高亮左侧导航选项
highLightLeftNav() {
this.firstIndexCur = -1;
this.secondIndexCur = -1;
this.customNav.forEach((item, index) => {
if(this.pathName.indexOf(item.pathUrl) !== -1) {
this.firstIndexCur = index;
return;
}else if(item.secondLevelNavList.length){
item.secondLevelNavList.forEach((sonItem, sonIndex) => {
if(this.pathName.indexOf(sonItem.pathUrl) !== -1) {
this.secondIndexCur = index + ',' + sonIndex;
return;
}
});
}
});
},
}
}
</script> <style lang="scss" type="text/css" scoped>
vue高亮一级、二级导航的更多相关文章
- Vue 中的Vue Router一级路由,二级路由,三级路由以及跳转
今天编写了一下Vue中的路由 先用命令行新建一个空的项目,并且我知道要用路由,就下载了路由的相关依赖 vue init webpack demo5 完毕之后进入所在的项目 cd demo5 之后用vs ...
- TP3.2二级导航与高亮显示
闲来无事,记记笔记 二级导航的实现,就是一个二级联动,嗯 先来看看数据库,我喜欢用一个表,表多了就不好玩了 二级代号取一级导航的代号就行了,做个简单的栗子: 代码部分: 看控制器,大头在这: < ...
- js二级导航
js写二级导航要点 1.ul li 2.js获取元素 3.setInterval(function(),time); 代码如下 <style type="text/css"& ...
- jQuery制作右侧边垂直二级导航菜单
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 纯CSS实现二级导航下拉菜单--css的简单应用
思想:使用css的display属性控制二级下拉菜单的显示与否.当鼠标移动到一级导航菜单的li标签时,显示二级导航菜单的ul标签.由于实现起来比较简单,所以在这里直接给出了参考代码. 1.纯CSS二级 ...
- 用jquery制作一个二级导航下拉菜单
1使用$(function(){...})获取到想要作用的HTML元素. 2通过使用children()方法寻找子元素. 3通过使用show()方法来显示HTML元素. 4通过 ...
- JS写的二级导航栏(利用冒泡原理)
今天给大家分享一种用JS写的导航栏,虽然我们工作中不会使用JS来做导航栏,为了练习我们用JS来做一个JS导航栏 这种方法要比其他方法代码量少很多,但是需要对事件冒泡有一定的理解,如果需要理解冒泡可以参 ...
- JavaScript(获取或设置html元素的宽,高,坐标),确定和判断鼠标是否在元素内部,二级导航菜单鼠标离开样式问题解决
设置: document.getElementById('id').style.width=value document.getElementById('id').style.height=va ...
- html css二级导航栏
二级导航栏制作: 1.将一级导航栏去除列表样式(list-style:none),并给予浮动,使其横向排列(float:left) 2.给每个li中添加一个<a></a>标签, ...
随机推荐
- ftp列出具体目录的所有目录,和目录按照文件类型列出
package com.haiyisoft.cAssistantWeb.util; import java.io.IOException; import java.io.PrintWriter; im ...
- Tomcat 8.5 配置自动从http跳转https
1.需要修改Tomcat目录下的conf/server.xml文件两处地方,Http端口,从默认的8080改为80:Https端口从8443改为443:(80\443分别都是http/https默认端 ...
- php文件夹上传下载控件分享
用过浏览器的开发人员都对大文件上传与下载比较困扰,之前遇到了一个php文件夹上传下载的问题,无奈之下自己开发了一套文件上传控件,在这里分享一下.希望能对你有所帮助. 以下是实例的部分脚本文件 这里我先 ...
- Day03:日期操作 / 集合框架(上)
日期操作 Java中的时间 · Java中的时间使用标准类库的Date类表示,是用距离一个固定时间点的毫秒数(可正可负,long类型)表达一个特定的时间点: · 固定的时间点叫纪元(epoch),是U ...
- JobHandle和依赖项
要当您调用作业的Schedule方法时,它将返回JobHandle.您可以在代码中使用一个JobHandle作为其他作业的依赖项.如果作业取决于另一个作业的结果,您可以将第一个作业JobHandle作 ...
- python高级 之(二) --- 类装饰器
装饰器-初级 在不改变原有函数逻辑功能的基础上,为函数添加新的逻辑功能.使代码可读性更高.结构更加清晰.冗余度更低 简介 """ 闭包: 函数嵌套的格式就是闭包.写装饰器 ...
- 【转载】深度学习中softmax交叉熵损失函数的理解
深度学习中softmax交叉熵损失函数的理解 2018-08-11 23:49:43 lilong117194 阅读数 5198更多 分类专栏: Deep learning 版权声明:本文为博主原 ...
- 【VS开发】设备控制台 (DevCon.exe) 示例
设备控制台 (DevCon.exe) 示例 本部分提供以下设备控制台 (DevCon.exe) 命令的示例: DevCon HwIDs 示例 1:查找所有硬件 ID 示例 2:使用模式查找硬件 ID ...
- 【Linux开发】linux设备驱动归纳总结(六):2.分享中断号
linux设备驱动归纳总结(六):2.分享中断号 xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx ...
- zip 命令
NAME zip - package and compress (archive) files SYNOPSIS zip [-aABcdDeEfFghjklLmoqrRSTuvVwXy ...