在vue中写一个跟着鼠标跑的div,div里面动态显示数据

2020-03-22 21:17:56

参考地址 在vue中写一个跟着鼠标跑的div,div里面动态显示数据

1.div应该放在body里面,这是我放在body中的一个div里面的div


<!-- 信息查看层 -->
<div class="floatDiv" :style="{display: isShow,left: floatLeft,top: floatTop}">
  <p>{{floatData.name}}</p>
  <p>{{level(floatData.level)}}</p>
  <p>{{floatData.intersectionStartRing}}环~{{floatData.intersectionEndRing}}环</p>
  <p v-if='floatData.estimatedStartTime'>{{floatData.estimatedViewStartTime}}-{{floatData.estimatedViewEndTime}}</p>
</div>

2.效果图:移动到红色剑头的区域显示对应的消息 

3.鼠标事件

1
<div v-on:mousemove="dataDetails($event, item)" v-on:mouseleave="hiddenDetail($event)" v-for="(item, index) in sectionDiagram" <br>:style="{left: item.sqrareLeft + 'px', width: item.width + 'px',zIndex: 88 + index}" :key='index' class="middleBoxBgmSquare" <br>:class="square(item.passState)"><br></div>

methods里面的代码

1
2
3
4
5
6
7
// 信息显示层
dataDetails (e, data) {
  this.floatData = data
  this.floatLeft = e.clientX - 195 + 'px' // 减去外层div的left距离
  this.floatTop = e.clientY - 55 + 'px'
  this.isShow = 'inline-block'
},


  • 2017-02-09 09:02:26

    两列布局——左侧宽度固定,右侧宽度自适应的两种方法

     关于左侧宽度固定,右侧宽度自适应两列布局的一种很常用的方法我相信大家都知道。就是利用左侧元素浮动,或者绝对定位的方式使其脱离常规文档流,让两个块级元素能够在同一行显示。然后右侧元素 margin-left 的值等于左侧元素宽度,这时右侧元素将紧挨着左侧元素