vue项目nav导航栏的实现
来源:互联网 发布:军用望远镜软件下载 编辑:程序博客网 时间:2024/05/23 01:56
每一个网页项目都少不了导航栏,通过原始的方法基本上都是可以写出来的。但是要写出代码量少,冗余度低的代码就要动脑子思考一下了。
最近写了一个百度地图的项目,要求底部有一个导航栏。具体如下图:
首先,拿到了底部导航栏的所有图标图片,图片都有两种。灰色的代表未选中,选中的用带样色的图片替换。
先看一下,组件中 html结构:通过vue提供的v-for方法,进行遍历显示footNav这个数组。数组里边存放着{title:"银行",url:" ",url1:" "},将图片的 src与isSelect进行绑定,并进行判断,如果等于当前的title时即为选中当前的导航,显示选中时的图片url1。
<div class="footer"> <ul> <li v-for="item in footNav" @click="selectMapNav(item.title)"> <img :src="isSelect === item.title ? item.url1 : item.url" alt=""> <p>{{item.title}}</p> </li> </ul></div>
样式用的是扩展语言less写的,应该都能看懂,只是简单的嵌套了一下。给这个地步加一个宽为100%,固定的高度。因为要固定在底部显示,所以加了一个固定定位和背景颜色。写的是手机端项目,浏览器都比较新,所以不用考虑兼容问题。大胆的flex布局可以很方便的实现导航栏。
.footer ul{ width:100%; height:50px; position:fixed; bottom:0; z-index:1; background-color:#fff; display:flex; li{ text-align:center; flex:1; img{height:23px;width:23px;margin-top:5px;} p{font-size:0.1rem;height:15px;line-height:10px;} }}
在vue data () 中定义一个数组,里边存放每一个导航的标题,如‘银行’,未选中时显示的图片url,选中时的图片url1。isSelect表示当前选中的,默认选中银行。
isSelect: '银行',footNav: [{title: '银行', url: '../../../static/baiduMap/23@2x.png', url1: '../../../static/baiduMap/22@2x.png'}, {title: '公交 ', url: '../../../static/baiduMap/11@2x.png', url1: '../../../static/baiduMap/10@2x.png'}, {title: '地铁 ', url: '../../../static/baiduMap/13@2x.png', url1: '../../../static/baiduMap/12@2x.png'}, {title: '教育 ', url: '../../../static/baiduMap/15@2x.png', url1: '../../../static/baiduMap/14@2x.png'}, {title: '医院 ', url: '../../../static/baiduMap/17@2x.png', url1: '../../../static/baiduMap/16@2x.png'}, {title: '休闲 ', url: '../../../static/baiduMap/19@2x.png', url1: '../../../static/baiduMap/18@2x.png'}, {title: '购物 ', url: '../../../static/baiduMap/21@2x.png', url1: '../../../static/baiduMap/20@2x.png'}]
在methods方法中,写上html中调用的事件。通过html结构层那里的点击事件selectMapNav(item.title)传过来的title赋值给isSelect即可实现导航栏的点击状态的变化。
selectMapNav (title) { this.isSelect = title }
来看一下最终的结果,很完美。
阅读全文
1 0
- vue项目nav导航栏的实现
- sidebar-nav 配合nav-header 实现精美的侧边导航
- javascript nav导航栏
- 导航栏(nav)
- jquery nav鼠标跟随的导航
- swift初始化一个项目导航栏和标签栏(nav和tabbar)
- 51.avi nav导航列表实现;BaseAction的抽象;jstl自定义函数
- HTML5 - 经典的上中下三段式布局(并使用<nav>实现侧边导航链接)
- 使用HTML5 nav标签和无序列表ul标签实现导航栏
- [学习笔记] bootstrap(六): nav导航栏和面包屑导航
- NAV导航网格寻路(6) -- 寻路实现
- 导航<nav>,视频<video>
- 导航控制器Nav和UITableView的使用(转载)
- apprfamework 3.0如何去掉侧导航nav的默认滚动
- 使用html和css制作水平导航栏nav
- iOS设置导航栏背景及字体颜色--Nav
- Vue--导航栏菜单
- Nav导航网格寻路
- Class PLBuildVersion is implemented in both frameworks
- NOIP2015提高组 神奇的幻方
- QTcpSocket发送数据和自定义数据
- jstree中文github文档
- SHELL脚本编程进阶(二)
- vue项目nav导航栏的实现
- 微信小程序SetData的问题
- UOJ264 NOIP2016 day2 T2 蚯蚓(队列)
- 国内注册Gmail
- 摄像相机标定到底是啥?标定完成得到的参数有什么用?
- required 'Android.support.v4.app.Fragment' found 'android.app.Fragment.'错误解决
- 上传文档
- xgboost 参数介绍
- 如何开放 Azure 虚拟机 Ping 功能