Vue.js鼠标悬浮更换图片
2017-05-17 12:12
561 查看
Vue.js鼠标悬浮更换图片
最近自己做的项目中设计师要求分类栏中鼠标悬停更换图片,大致实现出来的效果就是这样:这个在jQuery中是个很简单的事,但是在vue中我还是第一次实现。
首先将所有的选中后图片都覆盖到没选中图片上
html代码如下
<ul> <li> <a href=""> <img src="../../../img/goods/study.png" alt="学习"> <img class="hide_tab" src="../../../img/goods/study_1.png" alt="学习"> </a> </li> <li> <a href=""> <img src="../../../img/goods/life.png" alt="生活"> <img class="hide_tab" src="../../../img/goods/life_1.png" alt="生活"> </a> </li> <li> <a href="" > <img src="../../../img/goods/sport.png" alt="运动"> <img class="hide_tab" src="../../../img/goods/sport_1.png" alt="运动"> </a> </li> <li> <a href=""> <img src="../../../img/goods/clothes.png" alt="服饰"> <img class="hide_tab" src="../../../img/goods/clothes_1.png" alt="服饰"> </a> </li> <li> <a href="" > <img src="../../../img/goods/hat.png" alt="鞋帽"> <imgclass="hide_tab" src="../../../img/goods/hat_1.png" alt="鞋帽"> </a> </li> <li> <a href="" > <img src="../../../img/goods/food.png" alt="食品"> <img class="hide_tab" src="../../../img/goods/food_1.png" alt="食品"> </a> </li> <li> <a href=""> <img src="../../../img/goods/other.png" alt="其他"> <img class="hide_tab" src="../../../img/goods/other_1.png" alt="其他"> </a> </li> 4000 </ul>
css代码如下
.right { float: left; ul { margin-left: 1px; li { display: inline-block; margin-left: 12px; width: 100px; height: 100px; a{ position: relative; display: inline-block; width: 100px; height: 100px; .hide_tab{ position: absolute; bottom: 0; } } } } }
其实就是很简单的通过position:absolute进行了布局,现在选中样式的图片已经全部覆盖到了没有选中样式图片之上了。
接下来就需要一个变量控制他们的显隐。这个变量应该是一个和每个分类一一对应的,那这个变量就不应该是一个简单的布尔值,而是一个数字,和每个分类图片对应。
我定义这个变量叫做active,在data中声明
data(){ return{ active: 0 } }
再定义一个方法控制active变量的变化
showActive(index) { this.active = index; }
方法中的index参数就是鼠标悬浮时传入的值
修改html代码如下
<ul> <li> <a href="" @mouseenter="showActive(1)" @mouseleave="showActive(0)"> <img src="../../../img/goods/study.png" alt="学习"> <img v-show="active === 1" class="hide_tab" src="../../../img/goods/study_1.png" alt="学习"> </a> </li> <li> <a href="" @mouseenter="showActive(2)" @mouseleave="showActive(0)"> <img src="../../../img/goods/life.png" alt="生活"> <img v-show="active === 2" class="hide_tab" src="../../../img/goods/life_1.png" alt="生活"> </a> </li> <li> <a href="" @mouseenter="showActive(3)" @mouseleave="showActive(0)"> <img src="../../../img/goods/sport.png" alt="运动"> <img v-show="active === 3" class="hide_tab" src="../../../img/goods/sport_1.png" alt="运动"> </a> </li> <li> <a href="" @mouseenter="showActive(4)" @mouseleave="showActive(0)"> <img src="../../../img/goods/clothes.png" alt="服饰"> <img v-show="active === 4" class="hide_tab" src="../../../img/goods/clothes_1.png" alt="服饰"> </a> </li> <li> <a href="" @mouseenter="showActive(5)" @mouseleave="showActive(0)"> <img src="../../../img/goods/hat.png" alt="鞋帽"> <img v-show="active === 5" class="hide_tab" src="../../../img/goods/hat_1.png" alt="鞋帽"> </a> </li> <li> <a href="" @mouseenter="showActive(6)" @mouseleave="showActive(0)"> <img src="../../../img/goods/food.png" alt="食品"> <img v-show="active === 6" class="hide_tab" src="../../../img/goods/food_1.png" alt="食品"> </a> </li> <li> <a href="" @mouseenter="showActive(7)" @mouseleave="showActive(0)"> <img src="../../../img/goods/other.png" alt="其他"> <img v-show="active === 7" class="hide_tab" src="../../../img/goods/other_1.png" alt="其他"> </a> </li> </ul>
只有在当前index和active相等时,才会显示已选中分类的图片。
而鼠标离开时,传入一个没有与之对应的0,这样就没有显示了。
相关文章推荐
- Vue.js鼠标悬浮更换图片功能
- JS鼠标悬浮切换图片示例
- 运用js更改图片的classname来改变悬浮状态,鼠标悬浮用js改变边框
- js实现鼠标悬浮给图片加边框的方法
- js中鼠标悬浮改变图片或内容
- vue.js 图片上传并预览及图片更换功能的实现代码
- 查看商品图片,鼠标悬浮图片放大js实现
- 鼠标悬浮图片显示原图 移出鼠标后原图消失 js
- js实现鼠标悬浮给图片加边框的方法
- js实现鼠标切换a标签时更换显示的图片
- js实现:会骂人的图片,不信鼠标移上来试试!
- js--鼠标移入移出小图片,显示隐藏大图片
- js自动更换图片代码(收藏)
- 单击鼠标切换图片JS
- 鼠标滚轮缩放图片(js)
- js 鼠标移动显示图片
- 鼠标移上后改变图片的js
- 鼠标链接热点更换图片
- js设置图片或文字自动左右滚动控制,鼠标经过停留
- JS控制鼠标在移入移出时,图片渐变的效果