Home > Web Front-end > JS Tutorial > Teach you step by step to use js to achieve a drag and drop effect

Teach you step by step to use js to achieve a drag and drop effect

藏色散人
Release: 2023-01-24 08:30:01
forward
2826 people have browsed it

This article brings you some information about front-end drag and drop Knowledge related to effect implementation, which mainly introduces how to use js to achieve a good-looking drag and drop effect? How to type and layout? For those who are interested, let’s take a look below. I hope it will be helpful to everyone.

Preface

Recently I saw a video with a drag effect. Many people commented that it didn’t work if they followed the drag effect. Also, the author didn’t reply to some of the questions raised by everyone. In the spirit of knowing it Of course, we need to know the psychology behind it. I have studied the implementation effect and understood its implementation principle. Here I will review the principle for you. What you learn is to make money

Preparation

Here We need to use font icons, so we directly import

  • from the iconfont Alibaba icon library to find the required icon and add it to the project
  • Find the project where the icon is located and click to view the link
  • Copy the address, or click the address to copy the address link after the jump

Teach you step by step to use js to achieve a drag and drop effect

<link>复制代码
Copy after login

Create the required structure

Put the structure we need first Write it out

  • draggable: Make the box draggable
  • style="--color:#e63e31"--color Let the box background color be displayed according to --color (linked to the css style below)
 <div>        <div>
            <i></i>
            <span>双鱼座</span>
        </div>
        <div>
            <i></i>
            <span>水平座</span>
        </div>
        <div>
            <i></i>
            <span>摩羯座</span>
        </div>
        <div>
            <i></i>
            <span>处女座</span>
        </div>
        <div>
            <i></i>
            <span>狮子座</span>
        </div>
    </div>复制代码
Copy after login

Writing style

Here, flex is used directly to layout the box

  • background-color: var(--color);var(--color) is or the color of a custom attribute
body{
  background-color: #000;
}
.list{  width: 300px;  height: 360px;  /* padding: 20px 0; */
  margin: 100px auto 0;  display: flex;
  flex-direction: column;
  justify-content: space-around;
}
.list-item{  width: 100%;  display: flex;
  align-items: center;  padding: 0 16px;
  border-radius: 10px;  /* margin-bottom: 20px; */background-color: var(--color);
}
.constellation{
  line-height: 2.5em;
  font-size: 20px;  color: #fff;
}
.list-item-img{  width: 30px;  height: 30px;
}
.list-item-title{
  margin-left: 20px;  color: #fff;
}// 移动动画class.list-item.moving{
background-color: transparent;border: 2px dashed #ccc;
}复制代码
Copy after login

Teach you step by step to use js to achieve a drag and drop effect

js writing drag and drop effects

First get the elements you need to use

// 获取整个listconst list = document.querySelector('.list')// 获取每一个盒子const item = document.querySelectorAll('.list-item')复制代码
Copy after login

When you start dragging, you need to add the moving class and set the moving effect

// 开始拖动
    list.ondragstart = e => {
        source_node = e.target
        recode(item)        setTimeout(() => {        // 拖拽时样式
            e.target.classList.add('moving')
        }, 0)        // 设置拖动效果
        e.dataTransfer.effectAllowed = 'move'
    }复制代码
Copy after login

During dragging, you need to determine whether it is from top to bottom or bottom to top, and compare the index of the dragged element with the index of the inserted element, so as to insert a node into the dragged element

Note: Nuggets on the code There will be bugs when going from top to bottom, but not in the browser. I personally think it should be a problem with the Nuggets on the code

 // 拖拽放入有效目标触发
    list.ondragenter = e => {
        e.preventDefault()        console.log(e.target.id, list)        if (e.target === list || e.target === source_node) {            return false
        }        const childer = Array.from(list.children)        const sourceIndex = childer.indexOf(source_node)        const targetIndex = childer.indexOf(e.target)        // console.log(sourceIndex, targetIndex)
        if (sourceIndex <p> Drag After dragging, remove the style during dragging</p><pre class="brush:php;toolbar:false">// 拖放结束
    list.ondragend = e => {
        e.target.classList.remove('moving')
    }复制代码
Copy after login

Explanation method

There are many unused or less used methods here, here are the explanations

  • ondragstart: When the user starts dragging an element or text selection, the dragstart event will be triggered
  • ondragover: When the element or text selection is dragged to the effective When the drag and drop target is on (once every few hundred milliseconds), the drag and drop event will be triggered
  • ondragenter: When the dragged element or text selection enters a valid drag and drop target , the dragenter event will be triggered
  • ondragend: The dragend event is triggered when the drag-and-drop operation ends (by releasing the mouse button or clicking the escape key).
  • e.dataTransfer.effectAllowed: Used to set the effect of drag and drop. Common parameters are (move, link, copy)
  • getBoundingClientRect :Return the element's information about the viewport
  • requestAnimationFrame:Redraw animation
  • cancelAnimationFrame: Used to cancel the requestAnimationFrame call request

All codes

##Ending

This small case is mainly for us to understand and use the draggable attribute and learn some drag and drop methods. What you learn is what you earn. Welcome everyone to communicate with me and learn together

Recommended study:《

JavaScript video tutorial

The above is the detailed content of Teach you step by step to use js to achieve a drag and drop effect. For more information, please follow other related articles on the PHP Chinese website!

Related labels:
source:juejin.im
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template