vue-router二级导航切换路由及高亮显示的实现方法


Posted in Javascript onJuly 10, 2019

这里以网易云音乐作为示例,效果图:

vue-router二级导航切换路由及高亮显示的实现方法

我们先一层一层写导航

先设计第一层

1.设计导航页面样式

第一个导航页面为Discover

Discover.vue:

<!-- -->
<template>
 <div>
 发现
 </div>
</template>


<script>
export default {
 name: "discover",
 data() {
 return {
 };
 }
};
</script>
<style scoped>
</style>

第二个导航页面为Mymusic

其余代码一样,注意要把name改为相应路由

name: "mymusic"

2.配置路由

index.js:

import DisCover from '@/components/DisCover'
import MyMusic from '@/components/MyMusic'
……

 routes: [
 {
  path: '/discover',
  name: 'discover',
  component: DisCover
 },
 {
  path: '/mymusic',
  name: 'mymusic',
  component: MyMusic
 }
 ]

3.使用router-link制作导航

我们创建一个新组件Guide.vue,把他插入到app.vue中

设计好路由的数据源:

guides:[
  {
   id:0,
   name:'发现音乐',
   link:'/discover'
  },{
   id:1,
   name:'我的音乐',
   link:'/mymusic'
  },
  {
   id:2,
   name:'朋友',
   link:'friend'
  },
  {
   id:3,
   name:'商城',
   link:'mall'
  },
  {
   id:4,
   name:'音乐人',
   link:'musician'
  },
  {
   id:5,
   name:'下载客户端',
   link:'download'
  }
  ]

Guide.vue:

<ul class="nav nav-pills main-nav">
   <li v-for="(item,index) in guides" :key="index" role="presentation"
   :class="item.id==guidecurrent?'guide-active':''"
    >
    <router-link :to="item.link">{{item.name}}</router-link>
    </li>
   
   </ul>

to:是我们的导航路径,要填写的是你在router/index.js文件里配置的path值

4.单页面多路由区域操作

我们在App.vue中加入<router-view>

<template>
 <div id="app">
 <Guide></Guide>
 <router-view/>
 </div>
</template>

<router-view>区域通过配置路由的js文件,来操作这些区域的内容

设计好样式后,我们可以发现我们的页面上出现了导航

vue-router二级导航切换路由及高亮显示的实现方法

那我们如何设置默认选项并未其设置样式呢?
先定义一个定义当前页面的变量:

guidecurrent:0

设置选中样式:

.guide-active{
 background: black;
}

.guide-active::after {
 content: "??";
 font-size: 8px;
 position: absolute;
 color: rgb(182, 15, 15);
 top: 87%;
 left: 50%;
 transform: translate(-10px, -5px);
}

通过v-bind属性将class属性赋给每一个<li>元素

也就是说只有当前页面的<li>元素才会被加载active样式

这里注意vue中的属性如果要以变量设置

必须要写成 v-bind:属性名]="[属性值]"的形式

<li v-for="(item,index) in guides" :key="index" role="presentation"
  :class="item.id==guidecurrent?'guide-active':''"
   >
  <router-link :to="item.link">{{item.name}}</router-link>
 </li>

下面我们设计二级导航

5.二级导航页面样式

与上面相同,我们创建两个.vue页面

Rank.vue和Recommend.vue

6.配置路由

index.js

routes: [
 {
  path: '/discover',
  name: 'discover',
  component: DisCover,
  children:[
  {path:'rec',component:reccommend},
  {path:'rank',component:rank},
  ]
 },
 {
  path: '/mymusic',
  name: 'mymusic',
  component: MyMusic
 }
 ]

6.配置二级导航的<router-link>

<ul class="nav nav-pills">
  <li role="presentation" v-for="(item,index) in guides" :key="index"
   :class="item.id==discovercurrent?'active':''"
  >
   <router-link :to="item.id">{{item.name}}</router-link>
  </li>
  </ul>

这时我们发现我们的二级导航已经出现了

vue-router二级导航切换路由及高亮显示的实现方法

同样,设置当前页面的变量,利用class变量以及三元表达式,实现功能

至此,我们的vue-router实现的二级导航就实现了

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
jquery checkbox,radio是否选中的判断代码
Mar 20 Javascript
JavaScript基本编码模式小结
May 23 Javascript
JavaScript保存并运算页面中数字类型变量的写法
Jul 06 Javascript
javascript如何实现360度全景照片问题汇总
Apr 04 Javascript
浅谈js中的in-for循环
Jun 28 Javascript
Javascript日期格式化format函数的使用方法
Aug 30 Javascript
Ajax使用原生态JS验证用户名是否存在
May 26 Javascript
Javascript中call,apply,bind方法的详解与总结
Dec 12 Javascript
react-router browserHistory刷新页面404问题解决方法
Dec 29 Javascript
Vue.js+Layer表格数据绑定与实现更新的实例
Mar 07 Javascript
Webpack 4.x搭建react开发环境的方法步骤
Aug 15 Javascript
node爬取新型冠状病毒的疫情实时动态
Feb 06 Javascript
Vue编程式跳转的实例代码详解
Jul 10 #Javascript
微信小程序在ios下Echarts图表不能滑动的问题解决
Jul 10 #Javascript
Vue事件修饰符native、self示例详解
Jul 09 #Javascript
如何自定义微信小程序tabbar上边框的颜色
Jul 09 #Javascript
微信小程序wx.request拦截器使用详解
Jul 09 #Javascript
javascript实现图片轮播代码
Jul 09 #Javascript
关于微信小程序map组件z-index的层级问题分析
Jul 09 #Javascript
You might like
PHP memcache扩展的三种安装方法
2009/04/26 PHP
修改php.ini以达到屏蔽错误信息并记录日志
2013/06/16 PHP
thinkphp多层MVC用法分析
2015/12/30 PHP
YII2框架中excel表格导出的方法详解
2017/07/21 PHP
父元素与子iframe相互获取变量和元素对象的具体实现
2013/10/15 Javascript
js文件Cookie存取值示例代码
2014/02/20 Javascript
详谈jQuery中的this和$(this)
2014/11/13 Javascript
jQuery使用after()方法在元素后面添加多项内容的方法
2015/03/26 Javascript
JavaScript正则表达式中的ignoreCase属性使用详解
2015/06/16 Javascript
BootStrap 获得轮播中的索引和当前活动的焦点对象
2017/05/11 Javascript
js用类封装pop弹窗组件
2017/10/08 Javascript
Angular 作用域scope的具体使用
2017/12/11 Javascript
vue.js实现的绑定class操作示例
2018/07/06 Javascript
layui 上传文件_批量导入数据UI的方法
2019/09/23 Javascript
微信小程序实现上拉加载功能示例【加载更多数据/触底加载/点击加载更多数据】
2020/05/29 Javascript
JS中队列和双端队列实现及应用详解
2020/09/29 Javascript
零基础写python爬虫之使用Scrapy框架编写爬虫
2014/11/07 Python
Python编程中用close()方法关闭文件的教程
2015/05/24 Python
Python 爬虫的工具列表大全
2016/01/31 Python
Python简单实现TCP包发送十六进制数据的方法
2016/04/16 Python
Python绘制三角函数图(sin\cos\tan)并标注特定范围的例子
2019/12/04 Python
django数据模型on_delete, db_constraint的使用详解
2019/12/24 Python
python json load json 数据后出现乱序的解决方案
2020/02/27 Python
Tensorflow全局设置可见GPU编号操作
2020/06/30 Python
如何使用python-opencv批量生成带噪点噪线的数字验证码
2020/12/21 Python
来自世界各地的饮料:Flavourly
2019/05/06 全球购物
事业单位竞聘上岗实施方案
2014/03/28 职场文书
大专生自我鉴定怎么写
2014/09/16 职场文书
大学拉赞助协议书范文
2014/09/26 职场文书
2014光棍节单身联谊活动策划书
2014/10/10 职场文书
党的群众路线教育实践活动个人整改措施
2014/10/27 职场文书
2014年化工厂工作总结
2014/11/25 职场文书
大班上学期个人总结
2015/02/13 职场文书
python文件目录操作之os模块
2021/05/08 Python
springboot集成flyway自动创表的详细配置
2021/06/26 Java/Android
浅谈如何保证Mysql主从一致
2022/03/13 MySQL