HTML5新特性drag API 实现拖放功能(下)

简介: 接上文。

三、dataTransfer对象


上面只是简简单单地实现了拖放功能,但并没用利用该功能做出什么实际性的功能,这里我们介绍一个拖放事件中事件对象上的一个特别重要的属性——dataTransfer


我们通过 event.dataTransfer 来获取该对象,其主要的作用就是从被拖放元素向目标元素传递一个字符串数据


(1)方法


dataTransfer上有两个方法,如下表所示


方法 含义
setData 设置字符串,并设置数据类型
getData 获取对应数据类型的字符串


setData() 方法接收两个参数,第一个参数表示的是字符串的数据类型,HTML5规定了两种数据类型,分别是 text/plaintext/uri-list,前者表示普通字符串,后者表示URL字符串;第二个参数 就是用于存放的字符串


getData() 方法只接收一个参数,即需要接收的字符串类型


我们来简单使用一下这两个方法


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box{
            width: 100px;
            height: 100px;
            background-color: lightgreen;
        }
        .location{
            width: 100px;
            height: 100px;
            background-color: lightpink;
        }
    </style>
</head>
<body>
    <div class="box" draggable='true'></div>
    <div class="location"></div>
    <script>
  let box = document.querySelector('.box')
  // 为被拖放元素绑定 dragstart 事件
        box.addEventListener('dragstart', function(e) {
         // 设置类型为 text/plain 的 字符串
            e.dataTransfer.setData('text/plain', '我是拖放开始时被设置的字符串')
        })
        let located = document.querySelector('.location')
        located.addEventListener('dragenter', function(e) {
            e.preventDefault()
        })
        located.addEventListener('dragover', function(e) {
            e.preventDefault()
        })
        located.addEventListener('drop', function(e) {
         // 将被拖放元素放置到目标元素时获取字符串
            let res = e.dataTransfer.getData('text/plain')
            console.log(res);
        })
    </script>
</body>
</html>


来看下测试结果


c459ee284b54048d2bbd490dedb18a8a.jpg


(2)属性


dataTransfer对象 上还有两个比较常用的属性,如下表所示


属性 含义
dropEffect 被拖放元素的放置行为
effectAllowed 目标元素支持的放置行为


首先说一下,这个两个属性需要搭配使用,它们决定了被拖放元素目标元素 之间的关系的,当设定好两者的关系后,在进行拖动操作的时候,鼠标会根据不同的关系显示不同的样式,除此之外,没有别的特别的作用。


dropEffect 可以设置以下几个属性


含义
none 默认值。不能把拖动的元素放在这里
move 应该把拖动的元素移动到该目标元素
copy 应该把拖动元素复制到该目标元素
link 表示目标元素会打开被拖放进来的元素对应的链接


【注意】:dropEffect 属性必须在 dragenter事件 中设置,否则无效


effectAllowed 可以设置以下几个属性


含义
uninitialized 被拖放元素没有设置放置性为
none 被拖放元素不能有放置性为
copy 只允许值为 'copy' 的 dropEffect 目标元素
link 只允许值为 'link' 的 dropEffect 目标元素
move 只允许值为 'move' 的 dropEffect 目标元素
copyLink 只允许值为 'copy' 和 'link' 的 dropEffect 目标元素
copymove 只允许值为 'copy' 和 'move' 的 dropEffect 目标元素
linkMove 只允许值为 'link' 和 'move' 的 dropEffect 目标元素
all 只允许任意值的 dropEffect 目标元素


【注意】:effectAllowed 属性必须在 dragstart事件 中设置,否则无效


上面也说了,这两个属性基本上只是用来改变鼠标样式的,所以如果想实现特定的功能还得我们自己来重写事件的处理函数。


下面来看一个拖放实例:


需求: 将一段文本拖放到一个元素中


因为文本是默认支持的拖放元素,所以我们可以不对其做任何的事件绑定。


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .location{
            width: 100px;
            height: 100px;
            border: 1px solid black;
        }
    </style>
</head>
<body>
    <div class="box">我是一段测试文字</div>
    <div class="location"></div>
    <script>    
        let located = document.querySelector('.location')
        located.addEventListener('dragenter', function(e) {
            e.dataTransfer.dropEffect = 'copy'
            e.preventDefault()
        })
        located.addEventListener('dragover', function(e) {
            e.preventDefault()
        })
        located.addEventListener('drop', function(e) {
            e.target.innerHTML = e.dataTransfer.getData('text/plain')
        })
    </script>
</body>
</html>


测试动图


bd7ddca61fb298c0e9364778fa0fd54d.jpg


相关文章
|
16天前
|
Java API
Java 8新特性之Lambda表达式与Stream API
【5月更文挑战第17天】本文将介绍Java 8中的两个重要特性:Lambda表达式和Stream API。Lambda表达式是一种新的编程语法,它允许我们将函数作为参数传递给其他方法,从而使代码更加简洁。Stream API是一种用于处理集合的新工具,它提供了一种高效且易于使用的方式来处理数据。通过结合使用这两个特性,我们可以编写出更加简洁、高效的Java代码。
26 0
|
2天前
|
Java API
Java 8新特性之Lambda表达式和Stream API
【5月更文挑战第31天】本文将详细介绍Java 8中的两个重要特性:Lambda表达式和Stream API。通过对比传统编程方式,我们将探讨这两个特性如何简化代码、提高可读性和性能。文章还将通过实例演示如何使用Lambda表达式和Stream API进行集合操作、过滤和转换等任务。
|
3天前
|
Java API
Java 8新特性之Stream API详解
【5月更文挑战第30天】本文将详细介绍Java 8中的一个重要新特性——Stream API。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明式的方式处理数据,使得代码更加简洁、易读。文章将从Stream的基本概念、创建方式、常用操作以及实战案例等方面进行详细讲解,帮助读者深入理解并掌握Stream API的使用。
|
4天前
|
Java API
Java 8新特性之Lambda表达式与Stream API
【5月更文挑战第29天】本文将介绍Java 8中的两个重要特性——Lambda表达式和Stream API。Lambda表达式简化了函数式编程,使得代码更加简洁易读;而Stream API则为集合操作提供了更加高效且易于理解的方法。通过本文的学习,你将掌握这两个特性的基本用法,并了解如何在实际项目中应用它们。
|
5天前
|
Java API
Java 8新特性之Lambda表达式与Stream API
【5月更文挑战第28天】本文将介绍Java 8中的两个重要特性:Lambda表达式和Stream API。Lambda表达式是一种新的语法特性,允许我们将函数作为参数传递给方法或者作为返回值。而Stream API是一种处理集合的新方式,它提供了一种高效且简洁的方式来处理数据。通过学习这两个特性,我们可以编写出更加简洁、高效的Java代码。
|
5天前
|
Java API 数据处理
Java 8新特性之Stream API详解
【5月更文挑战第28天】本文将详细介绍Java 8中的一个重要新特性——Stream API。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明式的方式处理数据,使得代码更加简洁、易读。文章将从Stream的基本概念、创建方式、常用操作以及使用场景等方面进行详细讲解,帮助读者深入理解并掌握Stream API的使用。
|
5天前
|
Java API 数据处理
Java 8新特性之Lambda表达式与Stream API
【5月更文挑战第28天】本文将介绍Java 8中的两个重要特性:Lambda表达式和Stream API。Lambda表达式是一种新的编程语法,可以使代码更加简洁、易读。而Stream API则是一种处理数据的新方法,可以让我们更高效地处理集合数据。通过学习这两个特性,我们可以编写出更加简洁、高效的Java代码。
|
5天前
|
Java API
Java 8新特性之Stream API详解
【5月更文挑战第28天】本文将详细解析Java 8中的一个重要新特性——Stream API。Stream API是Java 8引入的一种新的数据处理方式,它允许我们以声明性和函数式的方式处理数据。我们将详细介绍Stream API的基本概念,使用方法,以及如何使用它来简化我们的代码。
|
5天前
|
Java API 数据处理
Java 8新特性:Stream API详解
【5月更文挑战第28天】本文将详细解析Java 8的新特性之一——Stream API。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明性和函数式的方式处理数据。我们将深入探讨Stream API的基本概念,使用方法以及一些高级技巧。无论你是Java初学者还是经验丰富的开发者,都可以从中获得有用的信息。
|
6天前
|
分布式计算 Java API
Java 8新特性之Stream API详解
【5月更文挑战第27天】 本文将详细解析Java 8中的一个重要新特性——Stream API。Stream API是Java 8中引入的一种新的数据处理方式,它允许我们以声明性和函数式的方式处理数据。我们将深入探讨Stream API的基本概念,使用方法以及一些高级技巧。无论你是Java初学者还是资深开发者,本文都将帮助你更好地理解和使用Stream API。