DOM事件有很多不同类型,例如,有鼠标事件,有键盘事件。接下来通过一个实例来讲解几个常见的鼠标事件:
首先,创建一个简单地页面,如下:
HTML代码如下:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
<title>登录面板拖拽</title>
<script type="text/javascript" src="js/drag.js"></script>
<style type="text/css">
#drag_div{
position:absolute;
background-color: #eeeeee;
left:500px;
top: 200px;
width: 350px;
height: 200px;
border:1px solid #eeeeee;
border-radius: 1em;
}
.head{
border-bottom: 1px solid #fff;
padding-left: 140px;
padding-top: 10px;
padding-bottom: 0px;
cursor:move;
}
.hTitle{
font-size: 24px;
}
.close{
position:relative;
}
.hClose{
position:absolute;
right: -23px;
top: -60px;
width: 46px;
height: 46px;
background:url(close.png);
text-decoration: none;
color:#000;
line-height:20px;
}
.body{
border-bottom:1px solid #fff;
}
form{
margin-top: 20px;
margin-bottom: 20px;
}
label{
display: inline-block;
text-align: right;
width: 100px;
margin-top: 10px;
}
.tInput{
margin-top: 10px;
border:1px solid #fff;
border-radius: 1em;
width: 180px;
padding:5px 5px 5px 5px;
}
.tInput:focus{
border-color: rgba(82,168,236,0.8);
box-shadow: 0 1px 1px rgba(0,0,0,0.075) inset,0 0 8px rgba(82,168,236,0.6);
outline: 0 none;
}
</style>
</head>
<body>
<div id="drag_div">
<div class="head">
<div class="hTitle">登录</div>
<div class="close"><a href="#" class="hClose"></a></div>
</div>
<div class="body">
<form>
<label>用户名:</label>
<input type="text" placeholder="输入用户名" class="tInput" />
<br/>
<label>密码:</label>
<input type="passward" placeholder="输入密码" class="tInput"/>
</form>
</div>
</div>
</body>
</html>
要实现当鼠标点击“登录”所在区域时,登录面板可以随着鼠标的移动在页面中移动,当鼠标按钮释放时,面板就不随鼠标移动了。
创建一个drag.js文件。首先,了解一个细节,在许多大型的网站中,许多元素通过class获取较为方便,然而getElementsByClassName()方法,在IE10之前是不支持的,所以通过封装一个函数,来实现跨浏览器通过className获取元素,代码如下:
function getElesByClass(classN,parent){
var oParent = parent?document.getElementById(parent):document;
var eles = [];
var allEles = oParent.getElementsByTagName("*");
for(var i = 0;i < allEles.length;i++){
if(allEles[i].className == classN){
eles.push(allEles[i]);
}
}
return eles;
}
下面先简单介绍三个事件:
window.onload = function(){
var hTitle = getElesByClass("hTitle")[0];
<span style="color:#ff0000;">hTitle.onmousedown</span> = fnDown; //按下任何鼠标按钮时触发
//点击关闭按钮
var oClose = getElesByClass("hClose")[0];
var oDrag = document.getElementById("drag_div");
oClose.onclick = function(){
oDrag.style.display = "none";
}
}
function fnDown(event){ //通过鼠标按下的event对象的clientX属性和clientY属性获取鼠标光标的位置坐标
event = event || window.event; //解决浏览器兼容问题
var oDrag = document.getElementById("drag_div");
//获取鼠标按钮按下时,鼠标光标与面板左边界及上边界的距离(用光标的位置坐标减去面板与浏览器的左距离及上距离)
var disX = event.clientX - oDrag.offsetLeft;
var disY = event.clientY - oDrag.offsetTop;
//当鼠标在页面中移动时
<span style="color:#ff0000;">document.onmousemove</span> = function(event){ //鼠标移动的event对象
event = event || window.event;
//计算当鼠标移动时,面板的位置
var l = event.clientX - disX;
var t = event.clientY - disY;
//计算当前页面的宽度及高度
var winW = document.documentElement.clientWidth || document.body.clientWidth;
var winH = document.documentElement.clientHeight || document.body.clientHeight;
//通过控制面板移动的范围,是的面板不会移动到浏览器页面之外
var maxW = winW - oDrag.offsetWidth-23;
var maxH = winH - oDrag.offsetHeight;
if(l < 0){
l = 0;
}else if(l > maxW){
l = maxW;
}
if(t < 20){
t = 20;
}else if(t > maxH){
t = maxH;
}
oDrag.style.left = l + "px";
oDrag.style.top = t + "px";
}
//释放鼠标
<span style="color:#ff0000;">document.onmouseup</span> = function(){
document.onmousemove = null; //DOM0级注销事件处理程序
document.onmouseup = null;
}
}
注意:
因篇幅问题不能全部显示,请点此查看更多更全内容