使用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高亮一级、二级导航的更多相关文章

  1. Vue 中的Vue Router一级路由,二级路由,三级路由以及跳转

    今天编写了一下Vue中的路由 先用命令行新建一个空的项目,并且我知道要用路由,就下载了路由的相关依赖 vue init webpack demo5 完毕之后进入所在的项目 cd demo5 之后用vs ...

  2. TP3.2二级导航与高亮显示

    闲来无事,记记笔记 二级导航的实现,就是一个二级联动,嗯 先来看看数据库,我喜欢用一个表,表多了就不好玩了 二级代号取一级导航的代号就行了,做个简单的栗子: 代码部分: 看控制器,大头在这: < ...

  3. js二级导航

    js写二级导航要点 1.ul li 2.js获取元素 3.setInterval(function(),time); 代码如下 <style type="text/css"& ...

  4. jQuery制作右侧边垂直二级导航菜单

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 纯CSS实现二级导航下拉菜单--css的简单应用

    思想:使用css的display属性控制二级下拉菜单的显示与否.当鼠标移动到一级导航菜单的li标签时,显示二级导航菜单的ul标签.由于实现起来比较简单,所以在这里直接给出了参考代码. 1.纯CSS二级 ...

  6. 用jquery制作一个二级导航下拉菜单

    1使用$(function(){...})获取到想要作用的HTML元素. 2通过使用children()方法寻找子元素.       3通过使用show()方法来显示HTML元素.       4通过 ...

  7. JS写的二级导航栏(利用冒泡原理)

    今天给大家分享一种用JS写的导航栏,虽然我们工作中不会使用JS来做导航栏,为了练习我们用JS来做一个JS导航栏 这种方法要比其他方法代码量少很多,但是需要对事件冒泡有一定的理解,如果需要理解冒泡可以参 ...

  8. JavaScript(获取或设置html元素的宽,高,坐标),确定和判断鼠标是否在元素内部,二级导航菜单鼠标离开样式问题解决

    设置: document.getElementById('id').style.width=value    document.getElementById('id').style.height=va ...

  9. html css二级导航栏

    二级导航栏制作: 1.将一级导航栏去除列表样式(list-style:none),并给予浮动,使其横向排列(float:left) 2.给每个li中添加一个<a></a>标签, ...

随机推荐

  1. JDK压缩指针

    https://www.cnblogs.com/iceAeterNa/p/4877549.html

  2. [SQL 高级查询运算符的用法 UNION (ALL),EXCEPT(ALL),INTERSECT(ALL) ]

    今天看到 三个查询运算符,给大家分享分享 为此我建立了两张表分别为 Articles 和  newArticles 我建立的时候,只建立了一张表 Articles   ,表 newArticles 是 ...

  3. 四、使用jsonpath-JSON Extractor提取复杂响应中的数组及其他字段

    一.jsonpath实时调试url http://jsonpath.com/ 二.对于复杂响应的提取字段 1.json字符串如下: { "code": 0, "data& ...

  4. SQLServer 简单数据拆分

    --1. 旧的解决方法(sql server 2000)   create table tb(id int,value varchar(30)) insert into tb values(1,'aa ...

  5. java二进制工具

    可以运用jdk工具监控java应用性能,再配合 jmeter 进行了一个长时间的加压,在加压过程中重点关注了系统资源的使用情况 D:\Program Files (x86)\Java\jdk1.8.0 ...

  6. ORA-00600: internal error code, arguments: [kdBlkCheckError]

    ORA-00600: internal error code, arguments: [kdBlkCheckError] Table of Contents 1. 现象 2. 分析 3. 故障处理 1 ...

  7. oracle imp 工具可能出现的问题

  8. Bat:IP切换,内外网切换,路由设置内外网同时连接

    1.IP切换: @echo off ::双冒号表示注释,注释只能单独一行写,@表示不让执行的命令又显示在屏幕上 cls ::清屏 color c ::设置显示字体颜色 set IP=10.10.17. ...

  9. charles工具页面介绍

    charles的主页面介绍 手机连上代理之后,每在手机上进行操作我们便会在charles上接收到请求.此时的charles页面将会变成如下密密麻麻的内容,故这节课我们来讲解一下Charles的主页面 ...

  10. fiddler的使用:抓包定位、模拟弱网

    一.fiddler抓包定位 Fiddler是一个http协议调试代理工具,它能够记录并检查所有你的电脑和互联网之间的http通讯,设置断点,查看所有的“进出”Fiddler的数据(cookie,htm ...