CSS拖曳盒子案例

让我为大家带来一个小案例吧!

html 复制代码
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
			* {
				margin: 0;
				padding: 0;
			}
			.box1 {
				width: 100px;
				height: 100px;
				background-color: black;
				margin-bottom: 10px;
				position: relative;
				left: 0;
				top: 0;
			}
			.box2 {
				width: 100px;
				height: 100px;
				background-color: pink;
				margin-bottom: 10px;
				margin-left: 200px;
			}
			.box3 {
				width: 100px;
				height: 100px;
				background-color: orange;
				margin-top: 120px;
				margin-left: 200px;
			}
		</style>
	</head>
	<body>
		<div class="box1"></div>
		<div class="box2"></div>
		<div class="box3"></div>
	</body>
	<script>
		//获取要移动的盒子
	 	var div = document.querySelector(".box1")
		//获取其他2个盒子
		var div1=document.querySelector(".box2")
		var div2=document.querySelector(".box3")
		div.onmousedown = function(e){
			//获取盒子距离页面多少
			var divX =div.offsetLeft
			var divY =div.offsetTop
			//获取盒子点击的xy坐标
			var downX =e.clientX
			var downY =e.clientY
			document.onmousemove=function(e){
			console.log(e);
			// if(div.offsetLeft<1){
			// 	alert("超出")
			// }
			//获取盒子点击的地方距离document点击的坐标的差
			var moveX =e.clientX - downX
			var moveY =e.clientY - downY
			//获取移动鼠标想放哪放哪
			// div.style.left =divX+moveX+"px"
			// div.style.top =divY+moveY+"px"
			//这个的中心点在中间
			div.style.left =e.clientX - div.offsetWidth/2+"px"
			div.style.top =e.clientY - div.offsetHeight/2+"px"
			//拿他们的宽高去判断坐标
			if(e.clientX<div1.offsetWidth+div.offsetWidth/2+200&&e.clientX>div1.offsetWidth+div.offsetWidth/2&&e.clientY>div1.offsetTop/2&&e.clientY<div1.offsetTop*2+40){
				console.log(div1.offsetTop);
				div1.style.backgroundColor="green"
				}else{
					div1.style.backgroundColor="pink"
				}
				//拿他们的距离去判断
			 if(e.clientX<div2.offsetWidth+div.offsetWidth/2+200&&e.clientX>div1.offsetWidth+div.offsetWidth/2&&e.clientY>div2.offsetTop-div.offsetHeight/2&&e.clientY<div2.offsetTop+div.offsetHeight+div.offsetHeight/2){
				div2.style.backgroundColor="blue"
				}else {
					div2.style.backgroundColor="orange"
				}
			}
		}
		//如果按起就不动
		div.onmouseup = function(){
			document.onmousemove = null
		}
	</script>
</html>

效果图:

感谢大家的阅读,如有不对的地方,可以向我提出,感谢大家!

相关推荐
逍遥德11 分钟前
CSS可以继承的样式汇总
前端·css·ui
读心悦17 分钟前
CSS3 选择器完全指南:从基础到高级的元素定位技术
前端·css·css3
学渣y1 小时前
React状态管理-对state进行保留和重置
javascript·react.js·ecmascript
_龙衣1 小时前
将 swagger 接口导入 apifox 查看及调试
前端·javascript·css·vue.js·css3
进取星辰2 小时前
25、Tailwind:魔法速记术——React 19 样式新思路
前端·react.js·前端框架
struggle20253 小时前
continue通过我们的开源 IDE 扩展和模型、规则、提示、文档和其他构建块中心,创建、共享和使用自定义 AI 代码助手
javascript·ide·python·typescript·开源
x-cmd3 小时前
[250512] Node.js 24 发布:ClangCL 构建,升级 V8 引擎、集成 npm 11
前端·javascript·windows·npm·node.js
夏之小星星3 小时前
el-tree结合checkbox实现数据回显
前端·javascript·vue.js
crazyme_63 小时前
前端自学入门:HTML 基础详解与学习路线指引
前端·学习·html
撸猫7914 小时前
HttpSession 的运行原理
前端·后端·cookie·httpsession