vue,页面悬浮按钮

// HTML代码
<div ref="dragArea" class="drag-area">
      <el-tooltip effect="dark" content="返回" placement="top">
        <el-button size="mini" icon="el-icon-back" circle @click="callback"></el-button>
      </el-tooltip>
    </div>
// JS代码
  mounted() {
    /**
   * 监听悬浮拖拽区域
   */
    this.$nextTick(() => {
      // 获取DOM元素
      let dragArea = this.$refs.dragArea;
      // 缓存 clientX clientY 的对象: 用于判断是点击事件还是移动事件
      let clientOffset = {};
      // 绑定鼠标按下事件
      dragArea.addEventListener("mousedown", (event) => {
        let offsetX = dragArea.getBoundingClientRect().left; // 获取当前的x轴距离
        let offsetY = dragArea.getBoundingClientRect().top; // 获取当前的y轴距离
        let innerX = event.clientX - offsetX; // 获取鼠标在方块内的x轴距
        let innerY = event.clientY - offsetY; // 获取鼠标在方块内的y轴距
        console.log(offsetX, offsetY, innerX, innerY);
        // 缓存 clientX clientY
        clientOffset.clientX = event.clientX;
        clientOffset.clientY = event.clientY;
        // 鼠标移动的时候不停的修改div的left和top值
        document.onmousemove = function (event) {
          dragArea.style.left = event.clientX - innerX + "px";
          dragArea.style.top = event.clientY - innerY + "px";
          // dragArea 距离顶部的距离
          let dragAreaTop = window.innerHeight - dragArea.getBoundingClientRect().height;
          // dragArea 距离左部的距离
          let dragAreaLeft = window.innerWidth - dragArea.getBoundingClientRect().width;
          // 边界判断处理
          // 1、设置左右不能动
          // dragArea.style.left = dragAreaLeft + "px";

          // 1.设置左侧边界
          if (dragArea.getBoundingClientRect().left <= 0) {
            dragArea.style.left = "0px";
          }
          // 2.设置右侧边界
          if (dragArea.getBoundingClientRect().left >= dragAreaLeft) {
            dragArea.style.left = dragAreaLeft + "px";
          }
          // 3、设置顶部边界
          if (dragArea.getBoundingClientRect().top <= 0) {
            dragArea.style.top = "0px";
          }
          // 4、设置底部边界
          if (dragArea.getBoundingClientRect().top >= dragAreaTop) {
            dragArea.style.top = dragAreaTop + "px";
          }
        };
        // 鼠标抬起时,清除绑定在文档上的mousemove和mouseup事件;否则鼠标抬起后还可以继续拖拽方块
        document.onmouseup = function () {
          document.onmousemove = null;
          document.onmouseup = null;
        };
      }, false);
      // 绑定鼠标松开事件
      dragArea.addEventListener('mouseup', (event) => {
        let clientX = event.clientX;
        let clientY = event.clientY;
        if (clientX === clientOffset.clientX && clientY === clientOffset.clientY) {
          console.log('click 事件');
        } else {
          console.log('drag 事件');
        }
      })
    });
  },
// css代码
<style scoped lang="scss">
.drag-area {
  position: fixed;
  right: 20px;
  top: 20%;
  z-index: 99999;
  padding: 13px;
  width: fit-content;
  opacity: 1;
  background-color: rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  box-shadow: 0px 2px 15px 0px rgba(9, 41, 77, 0.15);
  cursor: move;
  user-select: none;
  text-align: center;
}
<style>

可拖拽悬浮按钮
在这里插入图片描述

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现按钮在屏幕的固定位置并且可拖动,需要使用Vue的指令和事件绑定。具体实现步骤如下: 1. 在Vue组件中定义一个按钮元素,并设置其样式为固定定位,例如: ``` <template> <button class="fixed-btn" v-draggable>按钮</button> </template> <style> .fixed-btn { position: fixed; bottom: 20px; right: 20px; } </style> ``` 2. 定义一个自定义指令v-draggable用来实现按钮的拖拽功能,例如: ``` Vue.directive('draggable', { bind: function (el, binding, vnode) { el.style.position = 'absolute'; el.style.cursor = 'move'; el.addEventListener('mousedown', function (e) { let startX = e.clientX - el.offsetLeft; let startY = e.clientY - el.offsetTop; document.addEventListener('mousemove', move); document.addEventListener('mouseup', stop); function move (e) { el.style.left = e.clientX - startX + 'px'; el.style.top = e.clientY - startY + 'px'; } function stop () { document.removeEventListener('mousemove', move); document.removeEventListener('mouseup', stop); } }); } }); ``` 3. 在组件中引入该指令,并在按钮元素上使用该指令即可实现按钮的拖拽功能。 ``` <template> <button class="fixed-btn" v-draggable>按钮</button> </template> ``` 这样按钮就可以在屏幕上固定位置并且可拖动了。需要注意的是,该功能只是实现了按钮的拖拽,如果需要将按钮的位置保存到后端或者在刷新页面后仍然保持按钮的位置,需要在拖拽结束时将按钮的位置信息发送到后端或者使用本地存储或Cookie等技术来保存位置信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值