Maoyl's blog Maoyl's blog
首页
  • 前端基础

    • HTML
    • CSS
    • CSS动画
    • JavaScript文章
    • stylus
  • 性能优化

    • 《性能优化》笔记
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《JavaScript设计模式》笔记
    • 《TypeScript 从零实现 axios》
    • TypeScript笔记
    • JS设计模式总结笔记
  • 前端框架

    • Vue相关
    • React相关
  • 前端监控

    • 前端监控简介
  • 学习笔记

    • 《Vue》笔记
    • 《React》笔记
    • 小程序学习笔记
  • 后端基础

    • Nodejs
  • 学习笔记

    • 数据结构
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • 网页性能
  • 学习笔记

    • 《Git》学习笔记
    • 《Vim》学习笔记
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

maoyln

日日行,不怕千万里
首页
  • 前端基础

    • HTML
    • CSS
    • CSS动画
    • JavaScript文章
    • stylus
  • 性能优化

    • 《性能优化》笔记
  • 学习笔记

    • 《JavaScript教程》笔记
    • 《JavaScript高级程序设计》笔记
    • 《ES6 教程》笔记
    • 《JavaScript设计模式》笔记
    • 《TypeScript 从零实现 axios》
    • TypeScript笔记
    • JS设计模式总结笔记
  • 前端框架

    • Vue相关
    • React相关
  • 前端监控

    • 前端监控简介
  • 学习笔记

    • 《Vue》笔记
    • 《React》笔记
    • 小程序学习笔记
  • 后端基础

    • Nodejs
  • 学习笔记

    • 数据结构
  • 技术文档
  • GitHub技巧
  • 博客搭建
  • 网页性能
  • 学习笔记

    • 《Git》学习笔记
    • 《Vim》学习笔记
  • 学习
  • 面试
  • 心情杂货
  • 实用技巧
  • 友情链接
关于
  • 网站
  • 资源
  • Vue资源
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • HTML

  • CSS

  • CSS动画

  • GSAP动画学习

  • JavaScript文章

    • MDN知识及拓展

      • new命令原理
      • js全屏模式
      • 公共滚动条样式(继承)
      • 拖拽操作
        • 拖拽操作
        • 相关API
          • draggable
          • onDrag
          • onDragStart
          • onDragEnd
          • onDragEnter
          • onDragOver
          • onDragLeave
          • onDrop
        • 设置拖拽反馈图像
      • iframe跨域问题
      • 浏览器语言播放
    • 常用工具

    • ECMAScript

    • 三级目录

  • stylus

  • 性能优化

  • 学习笔记

  • 前端
  • JavaScript文章
  • MDN知识及拓展
maoyln
2022-08-11
目录

拖拽操作

# 拖拽操作

文章根据自己实际操作及理解编写,更加完善的文档请查阅官方文档 (opens new window)

# 相关API

# draggable

  • 用于标识元素是否允许使用拖动

    • true,表示元素可以被拖动
    • false,表示元素不可以被拖动

# onDrag

  • 拖拽元素或选中的文本时持续触发

# onDragStart

  • 开始拖拽时触发一次

# onDragEnd

  • 拖拽结束出发一次

# onDragEnter

  • 当拖拽元素或选中的文本到一个可释放目标时触发一次

# onDragOver

  • 当元素或选中的文本被拖到一个可释放目标上时触发(每100毫秒触发一次)

# onDragLeave

  • 当拖拽元素或选中的文本离开一个可释放目标时触发一次

# onDrop

  • 当元素或选中的文本在可释放目标上被释放时触发

  • 由于onDragOver用了节流(100ms执行一次),所以使用此api需要配合onDragOver配合使用,具体代码如下

<div
  onDragOver={(e) => {
    // 阻止冒泡-必加
    e.preventDefault();
  }}
  onDrop={() => {
    console.log("onDrop事件触发");
  }}
></div>
1
2
3
4
5
6
7
8
9

# 设置拖拽反馈图像

拖动时自定义图标可以使用该方法

当拖拽发生时,会生成拖拽目标的一个半透明图像(触发"dragstart (en-US)" 事件的元素),并在拖拽过程中跟踪鼠标指针。这个图像是自动创建的,所以你不需要自己创建它。但是,你可以使用 setDragImage() 方法来自定义拖拽反馈图像。

event.dataTransfer.setDragImage(image, xOffset, yOffset);
1

这三个参数都是必要的。第一个是图像的引用。这个引用通常是一个 <img>元素,但也可以是<canvas>或任何其他元素。生成的反馈图像就是该图像在屏幕上的样子,以图像原始的大小绘制。setDragImage() 方法的第二、三个参数是图像位置相对于鼠标指针位置的偏移量。

# 实例详解

# 下面官方给的例子
function dragWithCustomImage(event) {
  var canvas = document.createElementNS("http://www.w3.org/1999/xhtml","canvas");
  canvas.width = canvas.height = 50;

  var ctx = canvas.getContext("2d");
  ctx.lineWidth = 4;
  ctx.moveTo(0, 0);
  ctx.lineTo(50, 50);
  ctx.moveTo(0, 50);
  ctx.lineTo(50, 0);
  ctx.stroke();

  var dt = event.dataTransfer;
  dt.setData('text/plain', 'Data to Drag');
  dt.setDragImage(canvas, 25, 25);
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16

上述方法拖拽的过程中可能实现不了我们预期的效果,因为拖拽是瞬间的事情,而绘制拖拽的图标需要时间,我们开始拖拽的时候还没有图标还没有绘制完成,拖拽图标就不会改变;

# 优化方案

先准备好会在所需图标,拖拽开始的时候直接使用即可

  const createElementImg = () => {
    // var imgNode = document.createElement( 'img' );
    const imgNode: any = new Image();
    imgNode.src = dragIcon;
    dragIconRef.current = imgNode;
  }

  /**
   * 开始拖拽callback
   */
  const handleDragStartCallback = (type: any, event: any, info: any) => {
    event.dataTransfer.setDragImage(dragIconRef.current, 19, 50);
    console.log('开始拖拽');
  };
1
2
3
4
5
6
7
8
9
10
11
12
13
14
编辑 (opens new window)
上次更新: 2025/04/18, 01:42:12
公共滚动条样式(继承)
iframe跨域问题

← 公共滚动条样式(继承) iframe跨域问题→

最近更新
01
GSAP动画库——如何高效写动画
04-17
02
自适应方案PxToRem
09-10
03
性能优化-requestAnimationFrame
08-10
更多文章>
Theme by Vdoing | Copyright © 2019-2025 备案号:京ICP备19058102号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式