vue实现nav导航栏的方法
作者:羞羞的铁拳 时间:2024-05-09 15:18:22
每一个网页项目都少不了导航栏,通过原始的方法基本上都是可以写出来的。但是要写出代码量少,冗余度低的代码就要动脑子思考一下了。
最近写了一个百度地图的项目,要求底部有一个导航栏。具体如下图:
首先,拿到了底部导航栏的所有图标图片,图片都有两种。灰色的代表未选中,选中的用带样色的图片替换。
先看一下,组件中 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 }
来看一下最终的结果,很完美。
来源:http://blog.csdn.net/wang1006008051/article/details/78040862
标签:vue,nav,导航栏
0
投稿
猜你喜欢
python通过apply使用元祖和列表调用函数实例
2021-02-18 03:18:32
Django和Ueditor自定义存储上传文件的文件名
2021-02-26 02:43:17
python ChainMap管理用法实例讲解
2022-05-01 19:02:22
python机器学习库scikit-learn:SVR的基本应用
2022-04-25 09:38:34
Python常用数据结构和公共方法技巧总结
2021-10-18 06:02:01
python异常处理、自定义异常、断言原理与用法分析
2023-06-12 02:36:08
Python实现Const详解
2021-06-24 16:18:40
vue项目中使用axios遇到的相对路径和绝对路径问题
2024-05-13 09:37:40
python八皇后问题的解决方法
2022-11-04 17:48:59
Pytorch可视化的几种实现方法
2023-06-11 17:44:57
python网络编程socket实现服务端、客户端操作详解
2022-11-28 14:23:20
ODBC连接数据库以SQLserver为例图文详解
2024-01-13 04:07:43
实现页面中按钮刷新的N种方法
2007-02-03 11:06:00
webpack-dev-server自动更新页面方法
2024-04-19 09:48:10
Python操作MongoDB数据库的方法示例
2022-09-03 13:48:40
yui3的AOP(面向切面编程)和OOP(面向对象编程)
2009-09-24 14:47:00
Python完成哈夫曼树编码过程及原理详解
2023-10-16 03:09:39
Mysql调优Explain工具详解及实战演练(推荐)
2024-01-13 07:46:43
可以实现在同一页面里的用多按钮进行提交吗?
2009-11-01 18:04:00
功能强大的php分页函数
2023-11-15 03:17:37