最近看到一个非常酷炫的menu插件,一直想把它鼓捣成vue形式,谁让我是vue的死灰粉呢,如果这都不算爱?。?开个小玩笑,我们一起来探索黑魔法吧。观看本教程的读者需要具备一定的vue和css3的知识。
1.效果演示
2.使用方法介绍
3.关键步骤讲解
pic_1
pic2
pic_3
在线演示:https://mingseng-w.github.io/vue-bloom-menu/
项目地址:github.com/MingSeng-W/vue-bloom-menu,clone项目到本地
a. 首先在单文件组件里引入menu组件,导入common文件夹stylus里的menuConfig.stylus.
b.配置相应的参数
demo
整个menu的实现关键在于计算menu展开后最后的坐标,以及展开与收缩的动画.(由于整个项目布局比较简单,所以这里主要讲解逻辑和动画的实现)
关键代码:
计算每个item的夹角
第二步,根据生成的坐标使用js动态生成animtion,并插入到样式文件中。
生成展开和收缩的keyframe
到这一步我们完成了点击menu展开与收缩。
item消失的keyframe
这里触发动画使用vue提供transition ,当元素的v-show为false时,也就是display为none时,触发动画。
每个item动画完成后都会触发animationEnd事件,监听item的animationEnd事件,当所有动画依次触发完毕之后,提醒menu置于关闭状态(父子组件通信 )。
我在menu组件里使用v-on监听animationEnd事件,item自己的动画执行后,通过$emit触发animationEnd事件,通知menu的动画计数count++,当count达到总的项目数的时候,menu进行关闭.
code
code
再次打开menu的时候检查与item绑定的showItem是否为false,是的话置为true。点击时需要拿到被点击item的index,得到全局的currentIndex即被点击的item的index。被点中的使用放大动画,否则使用缩小动画。
pic_6
关键代码
至此所有步骤讲解完毕