jQuery를 사용하여 div의 드래그 앤 드롭 기능을 구현하는 방법
1. 소개
프런트 엔드 개발에서 드래그 앤 드롭 기능은 매우 일반적인 상호 작용 방법이며 구현 방법이 비교적 간단하여 jQuery와 같은 프런트 엔드 프레임워크를 통해 구현되는 경우가 많습니다. 이번 글에서는 jQuery를 사용하여 div의 드래그 앤 드롭 기능을 구현하는 방법을 자세히 소개합니다.
2. 구현 단계
- HTML 구조
먼저 HTML에서 해당 구조를 설정해야 합니다. 즉, 드래그된 div 요소를 구현해야 합니다. 일반적으로 절대 위치 지정을 사용하는 것이 좋습니다. 해당 지역의 더 작은 곳에 배치합니다.
<div class="box"> <div class="drag"></div> </div>
- CSS 스타일
둘째, CSS를 사용하여 div의 너비, 높이, 배경색, 테두리 및 기타 속성을 설정하는 등 드래그된 요소의 스타일을 설정합니다.
.box { position: relative; width: 500px; height: 500px; background-color: #f2f2f2; border: 1px solid #dcdcdc; } .drag { position: absolute; width: 50px; height: 50px; background-color: #29b6f6; border-radius: 50%; }
- JS code
마지막으로 jQuery 또는 네이티브 JS 코드를 통해 드래그 기능을 구현합니다. 구체적인 구현 단계는 다음과 같습니다.
(1) 마우스 다운 이벤트, 이동 이벤트 및 마우스 업 이벤트를 드래그 요소에 바인딩합니다.
$('.drag').mousedown(function(e){ // 鼠标按下时的事件 }).mousemove(function(e){ // 鼠标移动时的事件 }).mouseup(function(e){ // 鼠标抬起时的事件 });
(2) 마우스 다운 이벤트에서 현재 드래그된 요소의 위치와 마우스의 위치를 저장합니다.
var box = $(".box"); var drag = $(".drag"); // 拖动元素的位置 var dragX = drag.offset().left - box.offset().left; var dragY = drag.offset().top - box.offset().top; // 鼠标的位置 var mouseX = e.pageX; var mouseY = e.pageY;
(3) 마우스 이동 이벤트에서 드래그된 요소가 이동해야 하는 거리를 계산하고, 드래그된 요소의 왼쪽 및 위쪽 값을 변경하여 요소의 드래그를 구현합니다.
var moveX = e.pageX - mouseX; var moveY = e.pageY - mouseY; drag.css({ left: dragX + moveX + "px", top: dragY + moveY + "px" });
(4) 마우스업 이벤트에서는 저장된 마우스 위치와 드래그된 요소 위치를 지웁니다.
mouseX = 0; mouseY = 0; dragX = 0; dragY = 0;
3. 전체 코드
<!DOCTYPE html> <html> <head> <title>jQuery拖动实例</title> <meta charset="utf-8"> <style type="text/css"> .box { position: relative; width: 500px; height: 500px; background-color: #f2f2f2; border: 1px solid #dcdcdc; } .drag { position: absolute; width: 50px; height: 50px; background-color: #29b6f6; border-radius: 50%; } </style> </head> <body> <div class="box"> <div class="drag"></div> </div> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script type="text/javascript"> var box = $(".box"); var drag = $(".drag"); var dragX = 0; var dragY = 0; var mouseX = 0; var mouseY = 0; drag.mousedown(function(e){ dragX = drag.offset().left - box.offset().left; dragY = drag.offset().top - box.offset().top; mouseX = e.pageX; mouseY = e.pageY; }).mousemove(function(e){ if(mouseX === 0 || mouseY === 0 || dragX === 0 || dragY === 0) { return; } var moveX = e.pageX - mouseX; var moveY = e.pageY - mouseY; drag.css({ left: dragX + moveX + "px", top: dragY + moveY + "px" }); }).mouseup(function(e){ mouseX = 0; mouseY = 0; dragX = 0; dragY = 0; }); </script> </body> </html>
4. 요약
이 글에서는 주로 jQuery를 사용하여 div 요소의 드래그 기능을 구현하는 방법을 소개합니다. HTML, CSS 및 JS의 협력을 통해 이러한 대화형 효과를 쉽고 이해하기 쉽게 구현합니다. . 프론트엔드 개발자들에게 도움이 되길 바랍니다.
위 내용은 jQuery를 사용하여 div의 드래그 앤 드롭 기능을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











이 기사에서는 Data Fetching 및 기능 구성 요소의 DOM 조작과 같은 부작용을 관리하기위한 후크 인 React의 useEffect에 대해 설명합니다. 메모리 누출과 같은 문제를 방지하기 위해 사용법, 일반적인 부작용 및 정리를 설명합니다.

게으른로드는 필요할 때까지 컨텐츠로드를 지연시켜 초기로드 시간과 서버로드를 줄임으로써 웹 성능 및 사용자 경험을 향상시킵니다.

JavaScript의 고차 기능은 추상화, 공통 패턴 및 최적화 기술을 통해 코드 간접성, 재사용 성, 모듈성 및 성능을 향상시킵니다.

이 기사는 다중 연계 기능을 단일 연계 함수 시퀀스로 변환하는 기술 인 JavaScript의 카레에 대해 논의합니다. Currying의 구현, 부분 응용 프로그램 및 실제 용도와 같은 혜택, 코드 읽기 향상을 탐색합니다.

이 기사는 가상 Dom 트리를 비교하여 DOM을 효율적으로 업데이트하는 React의 조정 알고리즘을 설명합니다. 성능 이점, 최적화 기술 및 사용자 경험에 미치는 영향에 대해 설명합니다. 문자 수 : 159

기사는 Connect ()를 사용하여 React 구성 요소를 Redux Store에 연결하고 MapStateToprops, MapDispatchtoprops 및 성능 영향을 설명합니다.

이 기사는 REACT의 USECONTEXT를 설명하며, 이는 PROP 시추를 피함으로써 상태 관리를 단순화합니다. 중앙 집중식 상태 및 성능 개선과 같은 렌더링을 통해 성능 향상과 같은 이점에 대해 논의합니다.

기사에서는 extentdefault () 메서드를 사용하여 이벤트 처리기의 기본 동작 방지, 향상된 사용자 경험과 같은 이점 및 접근성 문제와 같은 잠재적 문제에 대해 논의합니다.
