简单实现windows和移动端的自由拖拽

参考于https://www.cnblogs.com/zjf-1992/p/6832941.html
以及JavaScript基础教程第九版 17.2

分为移动端和windows端:

1.移动端使用touchstart、touchmove事件直接解决,用evt.changedTouches[0].pageX - touchStart_x + boxStartX和evt.changedTouches[0].pageY - touchStart_y + boxStartY表示事件的位置和元素大小进而得出当前的left和top

2.wndows端通过mousedown、mousemove、mouseup三个阶段通过控制isDraging来判断事件的情况
evt.clientX和evt.clientY表示事件发生时候的横纵坐标
box().offsetLeft和box().offsetTop表示元素距离父级元素的边距
box().style.left和box().style.top通过写入改变元素的css属性

①mousedown 鼠标按下时操作流程;

  • 设置鼠标按下mousedown标识 isDraging
  • 获取目标元素初始化的位置 initObjX initObjY
  • 获取鼠标初始化的位置 initMouseX initMouseY
  • 通过目标元素初始化的位置与鼠标按下时的位置计算元素偏移距离objX/objY   
    *设置元素的位置(objX/objY)

②mousemove 鼠标移动时操作流程(动态改变目标元素left/top值;请参考图2-1);

  • 目标元素移动之前确保鼠标按下标识isDraging为true
  • 目标元素水平方向移动距离(moveX) = 当前鼠标移动时位置 - 鼠标按下时鼠标初始化位置 + 鼠标按下时目标元素水平方向初始化位置initObjX
  • 目标元素垂直方向移动距离(moveY) = 当前鼠标移动时位置 - 鼠标按下时鼠标初始化位置 + 鼠标按下时目标元素垂直方向初始化位置initObjX
  • 设置目标元素水平方向(moveX/moveY)移动距离

③mouseup鼠标离开时操作流程

  • 令isDraging=false;
  • 停止动画 mouseup鼠标离开事件绑定在document上,原因是鼠标拖动过快离开时有可能不在目标元素上

html部分


<html>
<head>
	<title>Drag n' drop touch demotitle>
	<meta name="viewport" content="width=device-width">
	<link rel="stylesheet" href="script02.css">
	<script src="http://code.jquery.com/jquery-2.1.0.js">script>
	<script src="drag.js">script>
head>
<body>
	<div id="draggable">
		Drag me!
		<p id="boxLocation">p>
	div>
body>
html>

js部分

//鼠标初始化位置
var initMouseX = 0;
var initMouseY = 0;
//元素的初始化位置
var initObjX = 0;
var initObjY = 0;

//鼠标按下标识
var isDraging = false;
//定义一个快速获取box元素
function box() {
     
    return document.getElementById("draggable");
}
window.addEventListener(
    "load",
    function(evt) {
     
        //移动端用touchmove事件
      $("#box").on("touchstart", function(evt) {
     
                    touchStart_x = evt.targetTouches[0].pageX;
                    touchStart_y = evt.targetTouches[0].pageY;
                    boxStartX = $("#box").position().left;
                    boxStartY = $("#box").position().top;
                })
                document.getElementById("draggable").addEventListener("touchmove", function(evt) {
     
                    evt.preventDefault();
                    var dragBox = document.getElementById("draggable");
                    dragBox.style.left = (evt.changedTouches[0].pageX - touchStart_x + boxStartX) + "px";
                    dragBox.style.top = (evt.changedTouches[0].pageY - touchStart_y + boxStartY) + "px";
                    document.getElementById("boxLocation").innerHTML = "Top: " + dragBox.style.top + "
Left: "
+ dragBox.style.left; }, false); //windows端用mousedown、mousemove、mouseup结合使用 var moveX = box().offsetLeft; var moveY = box().offsetTop; document.getElementById("draggable").addEventListener("mousedown", function(evt) { evt.preventDefault(); //鼠标初始化位置 initMouseX = evt.clientX; initMouseY = evt.clientY; //元素的初始化位置 initObjX = box().offsetLeft; initObjY = box().offsetTop; // initObjX = box().style.left; // initObjY = box().style.top; //鼠标按下标识 isDraging = true; }, false); document.getElementById("draggable").addEventListener("mousemove", function(evt) { if (isDraging) { //改变位置 moveX = evt.clientX - initMouseX + initObjX; moveY = evt.clientY - initMouseY + initObjY; //设置元素位置 box().style.left = moveX + 'px'; box().style.top = moveY + 'px'; } }, false); document.getElementById("draggable").addEventListener("mouseup", function(evt) { isDraging = false; document.getElementById("boxLocation").innerHTML = "Top: " + moveX + "
Left: "
+ moveY; }, false); }, false );

css部分

#draggable {
     
	position: absolute;
	background-color: #FFC;
	border: 5px solid yellow;
	width: 100px;
	height: 100px;
	padding: 50px;
	text-align: center;
	font-family: Albany, Georgia, "Times New Roman", serif;
}

在iis环境下容易报错security
该请求包含双重转义序列,而 Web 服务器上配置的请求筛选拒绝双重转义序列。
简单实现windows和移动端的自由拖拽_第1张图片
解决办法:
在本站点下的web.config下加入片段
简单实现windows和移动端的自由拖拽_第2张图片

<security>
<requestFiltering allowDoubleEscaping="True"/>
</security>

即可解决

你可能感兴趣的:(前端,javascript,html5)