<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<style>
div{width:100px;
height:100px;
}
#box{background:red; position:absolute; }
#box1{background:green;position:absolute;top:300px; left:300px;}
</style>
<script>
//两个碰撞的盒子。是建立在一个不动的基础上。所以可以根据不动的盒子求出四个方向的left和top值。然后再判断其是否碰撞,且碰撞的过程随时改变其层级,(原需 var 8个变量,现在只需4个变量)
function collText(obj,left,top,obj1){
var l1=obj.offsetLeft-obj.offsetWidth;
var t1=obj.offsetTop-obj.offsetHeight;
var r1=obj.offsetLeft+obj.offsetWidth;
var b1=obj.offsetTop+obj.offsetHeight;
if(left<l1||top<t1||left>r1||top>b1){
obj.style.zIndex=;
obj1.style.zIndex=;
return true;
}else{
obj.style.zIndex=;
obj1.style.zIndex=;
return false;
}
};
window.onload=function(){
var oBox=document.getElementById('box');
var oBox1=document.getElementById('box1');
oBox.onmousedown=function(ev){
var oEvent= ev || event;
var disX=oEvent.clientX-oBox.offsetLeft;
var disY=oEvent.clientY-oBox.offsetTop;
document.onmousemove=function(ev){
var oEvent= ev || event;
var l=oEvent.clientX-disX;
var t=oEvent.clientY-disY;
oBox.style.left=l+'px' ;
oBox.style.top=t+'px' ;
if(collText(oBox1,l,t,oBox)){
oBox1.style.background='green';
}else{
oBox1.style.background='yellow';
} };
document.onmouseup=function(){
document.onmousemove=null;
document.onmouseup=null;
oBox.reseaseCapture&&oBox.reseaseCapture();
};
oBox.setCapture&&oBox.setCapture();
return false;
}
oBox1.onmousedown=function(ev){
var oEvent= ev || event; var disX1=oEvent.clientX-oBox1.offsetLeft;
var disY1=oEvent.clientY-oBox1.offsetTop;
document.onmousemove=function(ev){
var oEvent= ev || event;
var le=oEvent.clientX-disX1;
var to=oEvent.clientY-disY1;
oBox1.style.left=le+'px' ;
oBox1.style.top=to+'px' ;
if(collText(oBox,le,to,oBox1)){
oBox.style.background='red';
}else{
oBox.style.background='#000';
}
};
document.onmouseup=function(){
document.onmousemove=null;
document.onmouseup=null;
oBox1.reseaseCapture&&oBox1.reseaseCapture();
} oBox1.setCapture&&oBox1.setCapture();
return false;
}
}
</script>
</head> <body>
<div id="box"></div>
<div id="box1"></div>
</body>
</html>

最新文章

  1. CSS基础及选择器
  2. Unity教程之再谈Unity中的优化技术
  3. Photoshop:通过图片理解通道原理
  4. LeetCode Find Minimum in Rotated Sorted Array II
  5. Android如何区分app原生和webview实现
  6. name值与id值在Js获取元素时的区别
  7. 北京时间28号0点以后Scott Hanselman同志台宣布dotnet core 1.0 rtm
  8. LeetCode: JumpGame 1 and 2
  9. worker进程中线程的分类及用途
  10. React的生命周期
  11. Day5模块-random模块
  12. Jvm虚拟机结构与机制
  13. ActiveMQ入门案例-生产者代码实现
  14. 微信小程序原生开发简介
  15. Hdoj 1203.I NEED A OFFER! 题解
  16. Linux安装Tomcat-Nginx-FastDFS-Redis-Solr-集群——【第九集之安装Tomcat+Nginx反向代理Tomcat集群】
  17. 一些Android手机的平台信息
  18. 《面向对象程序设计(java)》第七周学习总结
  19. ajax那些事儿
  20. Spark安装部署(local和standalone模式)

热门文章

  1. Codeforces Round #310 (Div. 2) A B C
  2. shell脚本处理大数据系列之(一)方法小结
  3. 适配IOS9中间遇到的一些问题
  4. MFC-CString 字符串分割
  5. 另一个分区工具GNU的parted[转自vbird]
  6. GUI、GUILayout、EditorGUI、EditorGUILayout
  7. 在Windows7上安装coreseek3.2同时在PHP下简单实现步骤
  8. 委托,C#本身的委托(Action Func)
  9. python扫描内网banner信息
  10. 博文推荐】Javascript中bind、call、apply函数用法