前端开发攻略---拖动归类,将元素拖拽到相应位置

1、演示

2、代码

<!DOCTYPE html>

<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>Document</title>

    <style>
      body {
        height: 95vh;
        display: flex;
        align-items: center;
        justify-content: center;
      }
      .main {
        display: flex;
      }
      .drag_ {
        width: 100px;
        height: 100px;
        display: flex;
        color: #fff;
        font-size: 20px;
        font-weight: bold;
        margin-right: 20px;
        border-radius: 7px;
        align-items: center;
        justify-content: center;
        background-color: bisque;
        -webkit-user-drag: element;
      }

      #drag1,
      .drag1 {
        background-color: red !important;
      }

      #drag2,
      .drag2 {
        background-color: pink !important;
      }

      #drag3,
      .drag3 {
        background-color: #409eff !important;
      }

      .files {
        width: 400px;
        min-height: 300px;
        border-radius: 5px;
        background-color: rgba(62, 196, 253, 0.376);
        margin-top: 100px;
        transition: all 0.8s;
      }

      .fileshover {
        transition: all 0.8s;
        background-color: black;
      }

      .folder {
        display: flex;
        flex-wrap: wrap;
        min-height: 300px;
        padding: 10px;
        gap: 10px;
      }

      .item_box {
        width: 50px;
        height: 50px;
        color: #fff;
        display: flex;
        font-size: 20px;
        font-weight: bold;
        border-radius: 5px;
        align-items: center;
        background: #ffe4c4;
        justify-content: center;
      }
    </style>
  </head>

  <body>
    <div>
      <div class="main">
        <div draggable="true" class="drag_">1</div>
        <div draggable="true" id="drag1" class="drag_">2</div>
        <div draggable="true" id="drag2" class="drag_">3</div>
        <div draggable="true" id="drag3" class="drag_">4</div>
      </div>
      <div class="files">
        <div class="folder"></div>
      </div>
    </div>

    <script>
      let data;
      let className;
      let index = null;
      const draggable = document.querySelectorAll(".drag_");
      const files = document.querySelector(".files");
      const folder = document.querySelector(".folder");
      // 开始拖拽事件
      for (let i = 0; i < draggable.length; i++) {
        draggable[i].addEventListener("dragstart", (event) => {
          index = i;
          data = event.target.innerText;
          className = event.target.id;
          event.dataTransfer.setData("name", data);
        });
      }

      // 拖拽元素,进入目标区域,事件处理程序
      files.addEventListener("dragover", (event) => {
        if (index == null) return;
        event.target.classList.add("fileshover");
        event.preventDefault();
      });

      // 拖拽离开事件处理程序
      files.addEventListener("dragleave", (event) => {
        event.target.classList.remove("fileshover");
      });

      // 拖拽释放的事件处理程序
      files.addEventListener("drop", (event) => {
        if (index == null) return;
        let div = document.createElement("div");
        div.innerText = data;
        div.className = `item_box ${className}`;
        event.target.classList.remove("fileshover");
        folder.appendChild(div);
        let parent = document.querySelector(".main");
        parent.removeChild(draggable[index]);
        index = null;
      });
    </script>
  </body>
</html>

3、JS代码解析

  1. dataclassNameindex:这些是全局变量声明。data 用来存储拖动的文本内容,className 存储拖动元素的类名,index 用来记录拖动元素的索引,初始值为 null

  2. draggablefilesfolder:这些是从文档中获取的元素引用。draggable 是所有带有 class 为 .drag_ 的元素集合,files 是具有 .files 类的元素,folder 是具有 .folder 类的元素。

  3. 第一个事件监听器:通过循环遍历所有 .drag_ 元素,为每个元素添加 dragstart 事件监听器。当元素开始拖拽时,会执行回调函数,其中记录了当前拖拽元素的文本内容到 data,类名到 className,并设置了 event.dataTransfer.setData("name", data),这是为了在拖放操作中传递数据。

  4. 第二个事件监听器:监听 .files 区域的 dragover 事件。这里阻止了默认的拖放行为,并且为 .files 区域添加了 .fileshover 类,用于指示拖放的目标区域。

  5. 第三个事件监听器:监听 .files 区域的 dragleave 事件。当拖拽元素离开目标区域时,移除 .fileshover 类。

  6. 第四个事件监听器:监听 .files 区域的 drop 事件。当拖拽元素放置到目标区域时,创建一个新的 <div> 元素,将拖拽元素的文本内容显示在该 <div> 中,并设置对应的类名。然后将这个新的 <div> 添加到 .folder 区域,并从父元素中移除被拖拽的元素。最后,重置 index 为 null,表示当前没有正在拖拽的元素。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/565052.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

我在本地部署通义千问Qwen1.5大模型,并实现简单的对话和RAG

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学&#xff0c;针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 汇总…

什么是防抖和节流?有什么区别? 如何实现?

防抖&#xff08;Debounce&#xff09;和节流&#xff08;Throttle&#xff09;是两种常用的技术手段&#xff0c;主要用于控制某个函数在一定时间内触发的次数&#xff0c;以减少触发频率&#xff0c;提高性能并避免资源浪费。 防抖&#xff08;Debounce&#xff09;的工作原…

掉落回弹问题(C语言)

一、N-S流程图&#xff1b; 二、运行结果&#xff1b; 三、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;float b 100;float sum 0;int i 0;//运算&#xff1b;for (i 1; i < 10; i){//运算&…

【oceanbase】安装ocp,ocp部署oceanbase

https://www.oceanbase.com/docs/common-ocp-1000000000584989 资源 iphostnamecpumem组件192.168.0.71obnode-000-071816oceanbase-ce192.168.0.72obnode-000-072816oceanbase-ce192.168.0.73obnode-000-073816oceanbase-ce192.168.0.74obproxy-000-07424obproxy-ce192.168.0…

【北京迅为】《iTOP-3588开发板系统编程手册》-第16章 串口应用编程

RK3588是一款低功耗、高性能的处理器&#xff0c;适用于基于arm的PC和Edge计算设备、个人移动互联网设备等数字多媒体应用&#xff0c;RK3588支持8K视频编解码&#xff0c;内置GPU可以完全兼容OpenGLES 1.1、2.0和3.2。RK3588引入了新一代完全基于硬件的最大4800万像素ISP&…

291个地级市资源错配指数、劳动和资本相对扭曲指数(2006-2021年)

01、数据介绍 资源错配指数&#xff08;Misallocation Index&#xff09;是一个用于衡量资源配置效率的指标&#xff0c;它衡量的是生产要素的配置是否合理&#xff0c;是否达到了最优的状态。资源错配指数越高&#xff0c;资源的利用效率越低。资源错配指数主要用于衡量各种生…

学习STM32第十七天

备份域详解 一、简介 在参考手册的电源控制章节&#xff0c;提到了备份域&#xff0c;BKPR是在RTC外设中用到&#xff0c;包含20个备份数据寄存器&#xff08;80字节&#xff09;&#xff0c;备份域包括4KB的备份SRAM&#xff0c;以32位、16位或8位模式寻址&#xff0c;在VBAT…

SpringCloud系列(9)--将服务消费者Consumer注册进Eureka Server

前言&#xff1a;上一章节我们介绍了如何将服务提供者注册进Eureka服务里&#xff0c;本章节则介绍如何将服务消费者Consumer注册进Eureka服务里 Eureka架构原理图 1、修改consumer-order80子模块的pom.xml文件&#xff0c;引入Eureka Clinet的依赖&#xff0c;然后reolad一下&…

SVD奇异值分解原理及应用

-------------------------------------------------------------------------------------------------------------------------------- 首先说明&#xff1a;本文的内容来自百家号“人工智能遇见磐创”大佬的整理&#xff0c;感谢原作者&#xff08;本文在原作者的基础上按…

找不到msvcp140dll,无法继续执行代码的详细解决方法

在我们日常使用计算机进行各类工作任务的过程中&#xff0c;时常会遭遇一些突发的技术问题。比如&#xff0c;有时在运行某个重要程序或应用软件时&#xff0c;系统会突然弹出一个令人困扰的错误提示&#xff1a;“电脑提示找不到msvcp140.dll文件&#xff0c;因此无法继续执行…

Mysql基础(二)数据类型和约束

一 数据类型 讲解主要的数据类型,不面面俱到,后续遇到具体问题再查询补充扩展&#xff1a; 知识点的深度和广度以工作为导向 ① int float M : 表示显示宽度&#xff0c;M的取值范围是(0, 255)例如: int(5),当数据宽度小于5位的时候在数字前面需要用字符填满宽度说明&…

双击复制elementui表格某个单元格的数据

提示:记录工作中遇到的需求及解决办法 文章目录 前言一、代码前言 在使用elementui的表格将数据展示出来时,我们想复制该表格区域对应的内容,但因为想复制的列不想太宽而数据太长导致数据省略,无法使用鼠标选择来全部复制到,所以想能不能实现一个双击该内容达到复制效果;…

VSCode 配置 C/C++ 环境

1 安装 VSCode 直接去官网(https://code.visualstudio.com/)下载并安装即可。 2 配置C/C编译环境 方案一 如果是在Windows&#xff0c;需要安装 MingW&#xff0c;可以去官网(https://sourceforge.net/projects/mingw-w64/)下载安装包。 注意安装路径不要出现中文。 打开 w…

声明式事务

文章目录 1.事务分类1.传统方式解决事务2.声明式事务 2.声明式事务案例1.需求分析2.解决方案分析3.数据表创建4.编写GoodsDao.java1.编写配置文件JdbcTemplate_ioc.xml2.单元测试 5.编写GoodsService.java6.配置事务管理器JdbcTemplate_ioc.xml7.进行测试 3.debug事务管理器Dat…

HubSpot流量转化:从访客到客户的转化策略

在当今数字化时代&#xff0c;企业营销获客的关键在于如何将网站访客转化为实际客户。作为HubSpot的合作伙伴&#xff0c;我们深知HubSpot软件在流量转化方面的强大功能。今天运营坛将带领大家深入探讨HubSpot流量转化的核心原理&#xff0c;并介绍如何利用个性化营销策略、构建…

实验2 NFS部署和配置

一、实训目的 1.了解NFS基本概念 2.实现NFS的配置和部署 二、实训准备 1.准备一台能够安装OpenStack的实验用计算机&#xff0c;建议使用VMware虚拟机。 2.该计算机应安装CentOS 7&#xff0c;建议采用CentOS 7.8版本。 3.准备两台虚拟机机&#xff08;客户机和服务器机&…

在React Router 6中使用useRouteLoaderData钩子获取自定义路由信息

在 React Router 6 中怎么像vueRouter一样&#xff0c;可以在配置路由的时候&#xff0c;定义路由的元信息(附加信息)&#xff1f;答案是可以的。稍有些复杂。核心是通过为每个路由定义了一个 loader 函数,用于返回自定义的路由信息&#xff0c;然后通过useRouteLoaderData 钩子…

机器人实验室LAAS-CNRS介绍

一、LAAS-CNRS介绍 1、缩写介绍 同样的&#xff0c;给出英文缩写的全称&#xff0c;以便理解。这里的LAAS&#xff08;Laboratory for Analysis and Architecture of Systems&#xff09;指法国的系统分析与架构实验室&#xff0c;CNRS&#xff08;Centre National de la Rec…

docker容器内ping外网能通,curl不通

排查原因是因为&#xff0c;在服务器上查看ifconfig&#xff0c;显示docker0的mtu是1500&#xff0c;网卡的mtu是1450。 mtu是指在网络通信中能够承载的最大数据包大小。一般情况下&#xff0c;docker的mtu默认为1500字节。 然而&#xff0c;不同的网络设备和网络配置可能会导…

Web3安全性:保护去中心化应用和用户的最佳实践

引言 随着Web3和去中心化应用&#xff08;DApps&#xff09;的迅速发展&#xff0c;我们进入了一个充满无限可能性的新世界。然而&#xff0c;这个数字天堂也伴随着一系列复杂的安全挑战。本文将深入探讨这些挑战&#xff0c;并提供一系列实用的安全建议&#xff0c;帮助你在W…