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)进入项目文件夹下 ...
随机推荐
- bnd -buildpath指令的用法
-buildpath的作用是为项目添加运行时依赖.这个依赖可以是workspace中的另一个项目或者是仓库中的另一个bundle. -buildpath指令只会在编译和构建时起作用,它从来不会被用来运 ...
- JetBrains 系列软件--操作数据库+centos系统
这系列软件贼强大! 能操作数据库 也能操作centos(linux)系统 由于这系列都有这两个功能,下面以最近常用的JetBrains PhpStorm 2017.2.1 x64来举例子: 一.操作数 ...
- firefox扩展开发(二):用XUL创建窗口控件
firefox扩展开发(二):用XUL创建窗口控件 2008-06-11 16:57 1.创建一个简单的窗口 <?xml version="1.0"?> <?xm ...
- HDU 4217
点击打开题目链接 题型就是数据结构.给一个数组,然后又k次操作,每次操作给定一个数ki, 从数组中删除第ki小的数,要求的是k次操作之后被删除的所有的数字的和. 简单的思路就是,用1标记该数没有被删除 ...
- 关于element-ui的弹框问题
el-dialog获取数据. el-dialog加载到页面中的时候,其实已经加载好了.只是默认隐藏了. 第一次点击的时候弹出,为何拿不到数据?之后再次操作就一点问题都没有了.
- Notepad++中Python脚本运行出现语法错误:IndentationError: unindent does not match any outer indentation level
使用Notepad++编辑python代码运行遇到了这个问题: IndentationError: unindent does not match any outer indentation leve ...
- C++中String字符串查找
在写C++程序中,总会遇到要从一个字符串中查找一小段子字符串的情况,对于在C中,我们经常用到strstr()或者strchr()这两种方法.而对于C++的string,我们往往会用到find(). C ...
- poj3261 后缀数组求重复k次可重叠的子串的最长长度
Milk Patterns Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 13669 Accepted: 6041 Ca ...
- thinkphp5.0 空模块、空控制器、空方法
空模块 'exception_handle' => function(Exception $e){ // 参数验证错误 if ($e instanceof \think\exception\Va ...
- MUI - 实现关闭除指定页面外的其他所有页面的功能
实现关闭除指定页面外的其他所有页面的功能 比如在实现注销登录功能时,要保证旧有的webweiw或缓存不影响新用户的操作,就需要在跳转到登陆页面前关闭其他页面. http://www.cnblogs.c ...