栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > JavaScript

React 实现拖拽功能的示例代码

JavaScript 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

React 实现拖拽功能的示例代码

本文介绍了React 实现拖拽功能的示例代码,分享给大家,具体如下:

实现效果:

因为工作中会用到 JIRA 所以想实现一下相似的功能,顺便学习一下 H5 的拖拽。不支持拖拽改变顺序,感觉有点麻烦,而且没必要。感觉相关的博文好少的,大部分都是直接上代码,没有解释。

图片默认可以拖动,其他元素的拖动效果同图片。正常的 div 是不能被拖动的,鼠标点击选择后移动没有效果,需要加  draggable="true" 使得元素可以被拖动。

拖拽相关的几个事件,有被拖动元素的事件,也有拖动进入的容器元素的事件。 

被拖拽元素的事件:ondragstart,ondragend 

放置元素的事件:ondragenter、ondragover、ondragleave、ondrop 

顾名思义,不需要解释。

需要注意是  ondragover 的默认事件 Reset the current drag operation to "none". 所以想让一个元素可放置,需要重写 ondragover 

element.ondragover = event => { 
  event.preventDefault();
  // ...
}

当一个元素是可放置的,拖拽经过时鼠标会变成加号(cursor: copy;)

有一个对象  dataTransfer 可以用来存储拖拽数据。

dragEle.ondragstart = e => e.dataTransfer.setData('item', e.target.id);
拖拽开始时触发,把被拖拽元素的 id 存入  e.dataTransfer 

然后在 ondrop 的时候 可以获取到这个值 (ondragenter、ondragover、ondragleave 获取不到...)

putEle.ondrop = function(e) {
   let id = e.dataTransfer.getData('item');
   // ...
}
简单的应用:



  
  
  
  document
  
  .wrapper {display: flex;border: 1px solid orangered;padding: 10px;}
  .col {border: 1px solid #808080;height: 500px;width: 200px;margin: 0 10px;padding: 10px;}
  .item {border: 1px solid #808080;margin: 5px 0;}
  


  
    
      item1
      item2
      item3
    
    
    
    
  
  

文章开头部分的 React 写的 demo


  
    
    
    
    
    
    
      .item {
 border: 1px solid #1da921;
 width: 180px;
 border-radius: 5px;
 box-shadow: 0 0 5px 0 #b3b3b3;
 margin: 5px auto;
 background: #fff;
      }
      .item.active {
 border-style: dashed;
      }
      .item-header {
 font-size: 12px;
 color: #9e9e9e;
 padding: 3px 5px;
      }
      .item-main {
 padding: 5px;
 font-size: 14px;
 color: #424242;
 height: 36px;
 overflow: hidden;
 text-overflow: ellipsis;
 display: -webkit-box;
 -webkit-box-orient: vertical;
 -webkit-line-clamp: 2;
      }
      .item-header-point {
 background: #ccc;
 float: right;
 padding: 0 4px;
 min-width: 10px;
 text-align: center;
 color: #fff;
 border-radius: 50%;
      }
      .col {
 border: 1px solid #d2d2d2;
 flex-grow: 1;
 width: 180px;
 height: 100%;
 margin: 0 2px;
 background: #eee;
 flex-grow: 1;
 display: flex;
 flex-direction: column;
      }
      .col-header {
 height: 40px;
 line-height: 40px;
 background: #1DA921;
 color: #fff;
 text-align: center;
      }
      .col-main {
 overflow: auto;
 flex-grow: 1;
      }
      .col-main.active {
 background: #00ad23;
 opacity: 0.1;
      }
      .task-wrapper {
 display: flex;
 height: 400px;
 width: 700px;
      }
    
  
  
    
    
  

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持考高分网。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/77580.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号