• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 如何使用HTML5实现拖放单个元素

如何使用HTML5实现拖放单个元素

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含拖放等相关知识,匿名希望在学习及工作中可以帮助到您
如何使用HTML5实现拖放单个元素?本篇文章将给大家介绍关于实现拖放HTML元素的JavaScript代码,下面一起来看具体的实现内容。

JavaScript

通过使用HTML5的拖放功能,您可以拖放HTML页面元素

我们来看具体的示例

代码如下

SimpleDragDrop.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
  <link rel="stylesheet" href="SimpleDragDrop.css" />
  <script>
    function load() {
      var box = document.querySelector('.box');
      box.addEventListener('dragstart', onDragStart, false);      
      var zone = document.querySelector('.dropzone');
      zone.addEventListener('dragover', onDragOver, false);
      zone.addEventListener('drop', onDrop, false);
   }    
function onDragStart(e) {
      e.dataTransfer.setData('text', this.id);
    }    
function onDragOver(e) {
      e.preventDefault();      
this.textContent = 'onDragOver';
    }    
function onDrop(e) {
      e.preventDefault();      
this.textContent = 'onDrop';
    }  
</script>
</head>
<body onload="load();">
  <div class="box" draggable="true"></div>
  <div id="dropzone" class="dropzone">
</div>
</body>
</html>

SimpleDragDrop.css

.box {
  width:32px;  
  height:32px;  
  border:solid 1px #002f9f;
}
.dropzone {
  margin-top:16px;  
  margin-bottom:16px;  
  width: 280px;  
  height: 64px;  
  border: solid 1px #808080;
}

说明:

<div class="box" draggable="true"></div>
  <div id="dropzone" class="dropzone"></div>

页面上显示两个上述的div,可以使用class =“box”,id =“dropzone”拖动的对象是放置接受区域的div。对于可拖动对象,可以将draggable =“true”设置为可拖动对象。

  function load() {
        var box = document.querySelector('.box');
      box.addEventListener('dragstart', onDragStart, false);
      var zone = document.querySelector('.dropzone');
      zone.addEventListener('dragover', onDragOver, false);
      zone.addEventListener('drop', onDrop, false);
   }
    function onDragStart(e) {
      e.dataTransfer.setData('text', this.id);
    }
    function onDragOver(e) {
      e.preventDefault();
      this.textContent = 'onDragOver';
    }
    function onDrop(e) {
      e.preventDefault();
      this.textContent = 'onDrop';
    }

上面的代码为每个元素分配拖放事件。

对于要拖动的元素,我们设置“dragstart”事件。启动拖动时,将执行onDragStart函数。

对于要删除的元素,设置“dragover”“drop”事件。当拖动的元素进入拖放区域,onDragOver功能被执行,当元件被丢弃onDrop功能将被执行。

在dragstart的情况下,你必须编写代码来设置dataTransfer对象的值。它不使用插入dataTransfer中的值,但是如果没有这个代码的话,在没有数据的情况下也会实现。

运行结果

使用Web浏览器显示上述HTML文件。将显示如下所示的效果。

JavaScript

拖动顶部的方框。如果将其拖动到底部框架,框架中将显示“onDragOver”。

JavaScript

将其放在框架中时,框架中会显示“onDrop”字符。

2345截图20181201114936.png

示例2:添加了事件的拖放元素的方法

代码如下

SimpleDragDrop2.html

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8" />
    <title></title>
  <link rel="stylesheet" href="SimpleDragDrop2.css" />
  <script>
    function load() {      
      var box = document.querySelector('.box');
      box.addEventListener('dragstart', onDragStart, false);
      box.addEventListener('dragend', onDragEnd, false);      
      var box = document.querySelector('.dropzone');
      box.addEventListener('dragenter', onDragEnter, false);
      box.addEventListener('dragover', onDragOver, false);
      box.addEventListener('dragleave', onDragLeave, false);
      box.addEventListener('drop', onDrop, false);
    }    
function onDragStart(e) {
      e.dataTransfer.setData('Text', this.id);      
      this.textContent = 'onDragStart';
    }    
function onDragEnd(e) {
      this.textContent = 'onDragEnd';
    }    
function onDragEnter(e) {
      this.textContent = 'onDragEnter';
    }    
function onDragOver(e) {
      e.preventDefault();      
      this.textContent = 'onDragOver';
    }    
function onDragLeave(e) {
            this.textContent = 'onDragLeave';
    }    
function onDrop(e) {
      e.preventDefault();      
      this.textContent = 'onDrop';
    }  
</script>
</head>
<body onload="load();">
  <div id="box" class="box" draggable="true"></div>
  <div id="dropzone" class="dropzone"></div>
</body>
</html>

SimpleDragDrop.css

.box {
  width:32px;  
  height:32px;  
  border:solid 1px #d01313;
}
.dropzone {
  margin-top:16px;  
  margin-bottom:16px;  
  width: 280px;  
  height: 64px;  
  border: solid 1px #808080;
}

说明:

 <div class="box" draggable="true"></div>
  <div id="dropzone" class="dropzone"></div>

如上例所示,页面上显示两页DIV。对于可拖动对象,请将draggable =“true”设置为可拖动对象。

function load() {
      var box = document.querySelector('.box');
      box.addEventListener('dragstart', onDragStart, false);
      box.addEventListener('dragend', onDragEnd, false);
      var box = document.querySelector('.dropzone');
      box.addEventListener('dragenter', onDragEnter, false);
      box.addEventListener('dragover', onDragOver, false);
      box.addEventListener('dragleave', onDragLeave, false);
      box.addEventListener('drop', onDrop, false);
    }
function onDragStart(e) {
      e.dataTransfer.setData('Text', this.id);      
      this.textContent = 'onDragStart';
    }
function onDragEnd(e) {      
            this.textContent = 'onDragEnd';
    }
function onDragEnter(e) {
      this.textContent = 'onDragEnter';
    }
function onDragOver(e) {
      e.preventDefault();
      this.textContent = 'onDragOver';
    }
function onDragLeave(e) {
      this.textContent = 'onDragLeave';
    }
function onDrop(e) {
      e.preventDefault();
      this.textContent = 'onDrop';
    }

上面的代码为每个元素分配拖放事件。
“dragstart”和“dragend”事件被分配给拖动侧的元素。一旦开始拖动,调用ondstart函数,拖动结束后,将被调用ondos agEs函数。

“dragenter”,“dragover”,“dragleave”和“drop”事件被分配给要拖动的元素。当拖动的元素进入拖放区域,执行onDragEnter函数的功能,在拖拽区域内拖动的状态下执行onDragOver函数,从拖拽的区域出来的话,将执行OnDragLeave函数。下拉拖动的元素时,将执行onDrop函数。

运行结果

使用Web浏览器显示上述HTML文件。将显示如下所示的效果。

您可能想查找下面的文章:

相关文章

  • 2018-12-03HTML5 组件Canvas实现电子钟的图文代码详情介绍
  • 2018-12-03 小强的HTML5移动开发之路(7)——坦克大战游戏1
  • 2018-12-03html5中设置或返回音视频是否在加载后即开始播放的属性autoplay
  • 2018-12-03HTML最新标准HTML5总结
  • 2018-12-03HTML5存储方式小结
  • 2018-12-03html5触摸事件判断滑动方向的实现
  • 2018-12-03HTML5教程之html 5 本地数据库(Web Sql Database)_html5教程技巧
  • 2018-12-03HTML5 或者JS可以获取移动设备信息吗?或者其他非开发语言的方法?
  • 2018-12-03html5之canvas起步的代码示例详解(图)
  • 2017-08-06HTML5如何实现元素拖拽

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • html5构建触屏网站之touch事件介绍
    • html5 main标签是什么意思?html5 main标签作用的详细介绍
    • datalist输入框与后台数据库数据的动态匹配
    • HTML怎么导出生成word文档?
    • Webkit做到了HTML5方式的客户端数据库存储
    • html5 Canvas画图教程(3)—canvas出现1像素线条模糊不清的原因
    • 一款html5 canvas实现的图片玻璃碎片特效
    • 关于老式浏览器兼容HTML5和CSS3的问题
    • html5 Canvas画图教程(1)—画图的基本常识
    • 做一个表白用的静态网页,有什么好的创意?

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有