vue基于 element-ui 实现菜单动画效果,任意添加 li 个数均匀撑满 ul 宽度
鼠标移至图标上时使用toolTip显示对应的中文提示文字 <template> <div class="em_tool">
<win :id="win.id" :data="win">
<div class="nav">
<input type="checkbox" class="nav__cb" id="menu-cb">
<div class="nav__content">
<ul class="nav__items" id="subnav">
<li v-for="(item,key) in tool" class="nav__item">
<!-- <span class="nav__item-text" prefix-icon="el-icon-users">{{item}}</span>-->
<el-tooltip class="item" placement="top-start">
<div slot="content">{{item.value}}</div>
<el-button :ref="item.id" :icon="item.icon" class="nav__item-text" @click="fn(item,key)"></el-button>
</el-tooltip>
</li>
</ul>
</div>
<label class="nav__btn" for="menu-cb"></label>
</div>
</win>
</div>
</template> <script>
export default {
name: "em_tools",
components: {
win
},
data() {
return {
win: {
id: "em_tool",
title: "",
top: "86%",
show: true,
width: 450,
resizable: false,
class: "em-tool-window"
},
input: '',
tool: [
{id:"tool_flyToScene",value: "menu1", icon: "el-icon-scene",control_id:"scene",fn:"toScene",trigger:"none"},
{id:"tool_transparent",value: "menu2", icon: "el-icon-transparent",control_id:"em_slider",fn:"showFn",trigger:true},
{id:"tool_coordinates",value: "menu3", icon: "el-icon-coordinates",control_id:"scene",fn:"xyz",trigger:true},
{id:"tool_data",value: "menu4", icon: "el-icon-data",control_id:"scene",fn:"scene_data",trigger:true},
{id:"tool_distance",value: "menu5", icon: "el-icon-distance",control_id:"scene",fn:"measure_drawLine",trigger:"none"},
{id:"tool_area",value: "menu6", icon: "el-icon-area",control_id:"scene",fn:"measure_drawPloy",trigger:"none"},
{id:"tool_hightly",value: "menu7", icon: "el-icon-hightly",control_id:"scene",fn:"",trigger:"none"},
{id:"tool_label",value: "menu8", icon: "el-icon-label",control_id:"scene",fn:"measure_clear",trigger:"none"}......
]
}
},
created() {
var bodywidth = Number(document.body.clientWidth);
var bodyheight = Number(document.body.clientHeight);
console.log(bodywidth);
this.win.left = bodywidth - 450;
/*this.win.top=bodyheight-130;*/ },
mounted(){
var subnav = document.getElementById('subnav'),
aLi = document.querySelectorAll('#subnav li'),
w = parseFloat(subnav.offsetWidth / aLi.length);//通过ul的宽度除以li的个数来计算每个li的宽度
console.log("个数:"+aLi.length);
for(var i=0;i<aLi.length;i++){
aLi[i].style.width = w + 'px';
}
},
methods: { }
}
</script> <style lang="scss" scoped>
@import "em_tools";
</style>
style部分
nav__item-text*, *:before, *:after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
.nav {
  overflow: hidden;
  float: right;
  right: 20px;
  bottom: 70px;
  width: auto;
  height: 60px;
  //background:linear-gradient(rgba(216, 187, 55, 0.8),rgba(20, 31, 55, 0.5));
  border-radius: 5px;
  -webkit-transform: translate3d(1%, 0, 0);
  transform: translate3d(1%, 0, 0);
  box-shadow: 0 10px 35px rgba(0, 0, 0, 0.2);
}
.nav__cb {
  z-index: -1000;
  position: absolute;
  left: 0;
  top: 0;
  opacity: 0;
  pointer-events: none;
}
.nav__content {
  position: relative;
  width: 60px;
  height: 100%;
  -webkit-transition: width 1s cubic-bezier(0.49, -0.3, 0.68, 1.23);
  transition: width 1s cubic-bezier(0.49, -0.3, 0.68, 1.23);
}
.nav__cb:checked ~ .nav__content {
  -webkit-transition: width 1s cubic-bezier(0.48, 0.43, 0.29, 1.3);
  transition: width 1s cubic-bezier(0.48, 0.43, 0.29, 1.3);
  background: url(../../assets/image/tool.bg2.png) no-repeat;
  width: 450px;
}
.nav__items {
  display: inline-flex;
  position: relative;
  width: 450px;
  height: 100%;
  padding-right: 45px;
  padding-left: 25px;
  list-style-type: none;
  font-size: 0;
}
.nav__item {
  display: inline-block;
  vertical-align: top;
  text-align: center;
  color: #bbb;
  font-size: 14px;
  line-height: 60px;
  font-family: Helvetica, Arial, sans-serif;
  font-weight: bold;
  -webkit-perspective: 1000px;
  perspective: 1000px;
  -webkit-transition: color 0.3s;
  transition: color 0.3s;
  cursor: pointer;
}
.nav__item:hover {
  color: #fff;
}
.nav__item-text {
  display: block;
  height: 100%;
  -webkit-transform: rotateY(-70deg);
  transform: rotateY(-70deg);
  opacity: 0;
  -webkit-transition: opacity 0.7s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
  transition: opacity 0.7s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
  transition: transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5), opacity 0.7s;
  transition: transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5), opacity 0.7s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
}
.nav__cb:checked ~ .nav__content .nav__item-text {
  -webkit-transform: rotateY(0);
  transform: rotateY(0);
  opacity: 1;
  -webkit-transition: opacity 0.2s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
  transition: opacity 0.2s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
  transition: transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5), opacity 0.2s;
  transition: transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5), opacity 0.2s, -webkit-transform 0.7s cubic-bezier(0.48, 0.43, 0.7, 2.5);
}
.nav__item:nth-child(1) .nav__item-text {
  -webkit-transition-delay: 0.7s;
  transition-delay: 0.7s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(1) .nav__item-text {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}
.nav__item:nth-child(2) .nav__item-text {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(2) .nav__item-text {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}
.nav__item:nth-child(3) .nav__item-text {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(3) .nav__item-text {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
.nav__item:nth-child(4) .nav__item-text {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(4) .nav__item-text {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
.nav__item:nth-child(5) .nav__item-text {
  -webkit-transition-delay: 0.3s;
  transition-delay: 0.3s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(5) .nav__item-text {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}
.nav__item:nth-child(6) .nav__item-text {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(6) .nav__item-text {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}
.nav__item:nth-child(7) .nav__item-text {
  -webkit-transition-delay: 0.1s;
  transition-delay: 0.1s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(7) .nav__item-text {
  -webkit-transition-delay: 0.6s;
  transition-delay: 0.6s;
}
.nav__item:nth-child(8) .nav__item-text {
  -webkit-transition-delay: 0s;
  transition-delay: 0s;
}
.nav__cb:checked ~ .nav__content .nav__item:nth-child(8) .nav__item-text {
  -webkit-transition-delay: 0.7s;
  transition-delay: 0.7s;
}
.nav__btn {
  position: absolute;
  right: 0;
  top: 0;
  width: 60px;
  height: 60px;
  padding: 22px 17px;
  cursor: pointer;
  background: url(../../assets/image/tool_button.png) no-repeat;
  background-position-x: center;
}
.nav__btn:before, .nav__btn:after {
  content: "";
  display: block;
  width: 28px;
  height: 4px;
  border-radius: 2px;
  background: #bbb;
  -webkit-transform-origin: 50% 50%;
  transform-origin: 50% 50%;
  -webkit-transition: background-color 0.3s, -webkit-transform 1s cubic-bezier(0.48, 0.43, 0.29, 1.3);
  transition: background-color 0.3s, -webkit-transform 1s cubic-bezier(0.48, 0.43, 0.29, 1.3);
  transition: transform 1s cubic-bezier(0.48, 0.43, 0.29, 1.3), background-color 0.3s;
  transition: transform 1s cubic-bezier(0.48, 0.43, 0.29, 1.3), background-color 0.3s, -webkit-transform 1s cubic-bezier(0.48, 0.43, 0.29, 1.3);
}
.nav__btn:before {
  margin-bottom: 10px;
}
.nav__btn:hover:before, .nav__btn:hover:after {
  background: #fff;
}
.nav__cb:checked ~ .nav__btn:before {
  -webkit-transform: translateY(7px) rotate(-225deg);
  transform: translateY(7px) rotate(-225deg);
}
.nav__cb:checked ~ .nav__btn:after {
  -webkit-transform: translateY(-7px) rotate(225deg);
  transform: translateY(-7px) rotate(225deg);
}
												
											vue基于 element-ui 实现菜单动画效果,任意添加 li 个数均匀撑满 ul 宽度的更多相关文章
- vue基于 element ui 的按钮点击节流
		vue的按钮点击节流 场景: 1.在实际使用中,当我们填写表单,点击按钮提交的时候,当接口没返回之前,迅速的点击几次,就会造成多次提交. 2.获取验证码,不频繁的获取. 3.弹幕不能频繁的发 基于这几 ... 
- 基于element UI 的上传插件
		为了不再重复的上传文件,做了一个统一选择文件和上传文件的 基于 element UI :http://element-cn.eleme.io 前端实现文件下载和拖拽上传 演示 用法 <uploa ... 
- vue开源Element UI表单设计及代码生成器
		在日常的开发工作中,表单开发是较为繁琐且重复的.本文介绍一个我自己写的,提高开发效率的小工具. 1 可视化设计器 设计器基于Element UI ,可通过点击或拖拽的方式设计基本表单, 设计器生成的代 ... 
- 基于Rebound制造绚丽的动画效果-入门篇
		基于Rebound制造绚丽的动画效果-入门篇 Rebound是什么? Rebound是一个来自 Facebook 公司的 Java物理和动画库.Rebound spring 模型可用于创建动画,让你感 ... 
- 关于vue.js element ui 表单验证 this.$refs[formName].validate()的问题
		方法使用前需了解: 来自”和“小编的小提示: 首先打印一下this.$refs[formName],检查是否拿到了正确的需要验证的form. 其次在拿到了正确的form后,检查该form上添加 ... 
- vue与element ui的el-checkbox的坑
		一,场景 通过使用checkbox,实现如图的场景, 点击某个tag,实现选中和非选中状态. 二, 官网的例子 通过切换checked值为true或者false来实现,一个checkbox的状态切换 ... 
- Vue框架Element UI教程-axios请求数据
		Element UI手册:https://cloud.tencent.com/developer/doc/1270 中文文档:http://element-cn.eleme.io/#/zh-CN gi ... 
- 基于element ui的图片预览插件
		写插件很简单,满足两个条件即可,一.基本的逻辑思路,二.熟悉插件语法要求.本次Vue插件也比较简单,点击“查看图片”用轮播的方式限制用户上传的图片,如图: 项目采用的是vue-element-admi ... 
- vue.js+element ui Table+spring boot增删改查
		小白初学,不懂的还是太多了,找了好多资料才做出来的先记录一下 1.先用Spring boot创建一个包含了增删改查的项目 2.创建vue.js项目 3.安装Element UI (1)进入项目文件夹下 ... 
随机推荐
- WCF ChannelFactory
			public static class WcfExtensions{ public static void Using<T>(this T client, Action<T&g ... 
- VUE中的style 样式处理的Scope (<style scope>)
			在VUE组件中,为了让样式私有化,不对全局造成污染,可以在style标签上添加scoped属性以表示它的只属于当下的模块. 但是这样的话,就会导致无法修改其他第三方组件样式,或者是内嵌的样式,解决方案 ... 
- 值得研究的J2EE开源项目推荐
			导读:笔者在学习J2EE的过程中发现了一些很有用,而且很值得学习的开源项目,在此推荐给大家. 关键词:J2EE 开源项目 J2SE JBoss SOA EJB 这篇文章写在我研究J2SE.J2EE ... 
- JasperStudio study..
			https://blog.csdn.net/shiyun123zw/article/details/79166448 
- Directx教程(27) 简单的光照模型(6)
			原文:Directx教程(27) 简单的光照模型(6) 从myTutorialD3D11_15到myTutorialD3D11_19的工程中,我们都只有一个光源,光源的位置在LightCla ... 
- 杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了
			ylbtech-杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了 1.返回顶部 1. 注意了!杨絮解决有办法了 2018-05-03 14:18 昨天中午经过一个理发店,门口蹲了个染黄发.系 ... 
- Libevent:8Bufferevents高级主题
			本章描述的是Libevent的bufferevent实现的一些高级特性,这对于普通应用来说并非必须的.如果你只是学习如何使用bufferevent,则应该跳过本章去阅读evbuffer的章节. 一:成 ... 
- Cacti 加入多台主机带宽汇聚
			前面我写了一个cacti加入主机带宽监控的博客.能够參考http://blog.csdn.net/dai451954706/article/details/35272465 .有时可能 ... 
- DENSE_RANK(),允许并列名次、名次不间断,如122344456
			将score按ID分组排名:dense_rank() over(partition by id order by score desc) 将score不分组排名:dense_rank() over(o ... 
- Java练习 SDUT-1132_斐波那契数列
			C/C++经典程序训练2---斐波那契数列 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 编写计算斐波那契(Fibon ... 
