鼠标移至图标上时使用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 宽度的更多相关文章

  1. vue基于 element ui 的按钮点击节流

    vue的按钮点击节流 场景: 1.在实际使用中,当我们填写表单,点击按钮提交的时候,当接口没返回之前,迅速的点击几次,就会造成多次提交. 2.获取验证码,不频繁的获取. 3.弹幕不能频繁的发 基于这几 ...

  2. 基于element UI 的上传插件

    为了不再重复的上传文件,做了一个统一选择文件和上传文件的 基于 element UI :http://element-cn.eleme.io 前端实现文件下载和拖拽上传 演示 用法 <uploa ...

  3. vue开源Element UI表单设计及代码生成器

    在日常的开发工作中,表单开发是较为繁琐且重复的.本文介绍一个我自己写的,提高开发效率的小工具. 1 可视化设计器 设计器基于Element UI ,可通过点击或拖拽的方式设计基本表单, 设计器生成的代 ...

  4. 基于Rebound制造绚丽的动画效果-入门篇

    基于Rebound制造绚丽的动画效果-入门篇 Rebound是什么? Rebound是一个来自 Facebook 公司的 Java物理和动画库.Rebound spring 模型可用于创建动画,让你感 ...

  5. 关于vue.js element ui 表单验证 this.$refs[formName].validate()的问题

        方法使用前需了解: 来自”和“小编的小提示: 首先打印一下this.$refs[formName],检查是否拿到了正确的需要验证的form. 其次在拿到了正确的form后,检查该form上添加 ...

  6. vue与element ui的el-checkbox的坑

    一,场景 通过使用checkbox,实现如图的场景, 点击某个tag,实现选中和非选中状态. 二, 官网的例子 通过切换checked值为true或者false来实现,一个checkbox的状态切换 ...

  7. Vue框架Element UI教程-axios请求数据

    Element UI手册:https://cloud.tencent.com/developer/doc/1270 中文文档:http://element-cn.eleme.io/#/zh-CN gi ...

  8. 基于element ui的图片预览插件

    写插件很简单,满足两个条件即可,一.基本的逻辑思路,二.熟悉插件语法要求.本次Vue插件也比较简单,点击“查看图片”用轮播的方式限制用户上传的图片,如图: 项目采用的是vue-element-admi ...

  9. vue.js+element ui Table+spring boot增删改查

    小白初学,不懂的还是太多了,找了好多资料才做出来的先记录一下 1.先用Spring boot创建一个包含了增删改查的项目 2.创建vue.js项目 3.安装Element UI (1)进入项目文件夹下 ...

随机推荐

  1. WCF ChannelFactory

    public static class WcfExtensions{    public static void Using<T>(this T client, Action<T&g ...

  2. VUE中的style 样式处理的Scope (<style scope>)

    在VUE组件中,为了让样式私有化,不对全局造成污染,可以在style标签上添加scoped属性以表示它的只属于当下的模块. 但是这样的话,就会导致无法修改其他第三方组件样式,或者是内嵌的样式,解决方案 ...

  3. 值得研究的J2EE开源项目推荐

    导读:笔者在学习J2EE的过程中发现了一些很有用,而且很值得学习的开源项目,在此推荐给大家. 关键词:J2EE 开源项目 J2SE JBoss SOA EJB   这篇文章写在我研究J2SE.J2EE ...

  4. JasperStudio study..

    https://blog.csdn.net/shiyun123zw/article/details/79166448

  5. Directx教程(27) 简单的光照模型(6)

    原文:Directx教程(27) 简单的光照模型(6)      从myTutorialD3D11_15到myTutorialD3D11_19的工程中,我们都只有一个光源,光源的位置在LightCla ...

  6. 杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了

    ylbtech-杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了  1.返回顶部 1. 注意了!杨絮解决有办法了 2018-05-03 14:18 昨天中午经过一个理发店,门口蹲了个染黄发.系 ...

  7. Libevent:8Bufferevents高级主题

    本章描述的是Libevent的bufferevent实现的一些高级特性,这对于普通应用来说并非必须的.如果你只是学习如何使用bufferevent,则应该跳过本章去阅读evbuffer的章节. 一:成 ...

  8. Cacti 加入多台主机带宽汇聚

            前面我写了一个cacti加入主机带宽监控的博客.能够參考http://blog.csdn.net/dai451954706/article/details/35272465 .有时可能 ...

  9. DENSE_RANK(),允许并列名次、名次不间断,如122344456

    将score按ID分组排名:dense_rank() over(partition by id order by score desc) 将score不分组排名:dense_rank() over(o ...

  10. Java练习 SDUT-1132_斐波那契数列

    C/C++经典程序训练2---斐波那契数列 Time Limit: 1000 ms Memory Limit: 65536 KiB Problem Description 编写计算斐波那契(Fibon ...