鼠标横向拖动div

本文介绍了如何使用JavaScript在HTML页面中实现一个名为scrollInit的函数,该函数通过监听mousedown、mousemove、mouseup和mouseleave事件,实现对带有idcontent4的元素的滚动条进行自定义拖动效果控制。
摘要由CSDN通过智能技术生成
scrollInit() {
      // 获取要绑定事件的元素
      const nav = document.getElementById("content4")
      var flag; // 鼠标按下
      var downX; // 鼠标点击的x下标
      var scrollLeft; // 当前元素滚动条的偏移量
      nav.addEventListener("mousedown", function (event) {
      flag = true;
      downX = event.clientX; // 获取到点击的x下标
      scrollLeft = this.scrollLeft; // 获取当前元素滚动条的偏移量
      });
      nav.addEventListener("mousemove", function (event) {
      if (flag) { // 判断是否是鼠标按下滚动元素区域
      var moveX = event.clientX; // 获取移动的x轴
      var scrollX = moveX - downX; // 当前移动的x轴下标减去刚点击下去的x轴下标得到鼠标滑动距离
      this.scrollLeft = scrollLeft - scrollX // 鼠标按下的滚动条偏移量减去当前鼠标的滑动距离
      }
      });
      // 鼠标抬起停止拖动
      nav.addEventListener("mouseup", function () {
      flag = false;
      });
      // 鼠标离开元素停止拖动
      nav.addEventListener("mouseleave", function (event) {
      flag = false;
      });
    }

  • 6
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
实现 div 横向拖拽,可以使用 Vue.js 和一些 JavaScript 库来实现。 首先,在 Vue.js 中创建一个拖拽事件。你可以使用 `v-on:mousemove` 来监听鼠标移动事件,并使用 `v-on:mousedown` 来监听鼠标按下事件。在鼠标按下事件中,你需要记录鼠标的当前位置。 接下来,在鼠标移动事件中,你需要计算鼠标的偏移量,并将偏移量添加到 div 的 left 样式中。这将使 div 沿着 x 轴移动。 当鼠标释放时,你需要清除鼠标事件监听器。 最后,你需要将这些逻辑封装在一个 Vue.js 组件中,以便在应用程序中使用。以下是一个简单的示例: ```html <template> <div class="container"> <div class="box" v-bind:style="{ left: left + 'px' }" v-on:mousedown="startDrag($event)"> {{ content }} </div> </div> </template> <script> export default { data() { return { left: 0, startX: 0, dragging: false, }; }, props: { content: { type: String, default: 'Hello World!', }, }, methods: { startDrag(event) { this.dragging = true; this.startX = event.clientX; window.addEventListener('mousemove', this.drag); window.addEventListener('mouseup', this.stopDrag); }, drag(event) { if (!this.dragging) { return; } const deltaX = event.clientX - this.startX; this.left += deltaX; this.startX = event.clientX; }, stopDrag() { this.dragging = false; window.removeEventListener('mousemove', this.drag); window.removeEventListener('mouseup', this.stopDrag); }, }, }; </script> <style> .container { position: relative; width: 100%; height: 100px; background-color: #f5f5f5; } .box { position: absolute; top: 0; height: 100%; width: 100px; background-color: #fff; border: 1px solid #ccc; display: flex; justify-content: center; align-items: center; cursor: move; } </style> ``` 在这个示例中,我们创建了一个 div 容器,并创建了一个包含文本内容的 div,并将其绑定到数据模型中。当用户按下鼠标并开始拖动 div 时,我们记录 div 的当前位置,并在每次移动时计算偏移量。当用户释放鼠标时,我们清除鼠标事件监听器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值