最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

javascript完美拖拽的实现方法_javascript技巧

来源:动视网 责编:小采 时间:2020-11-27 21:14:11
文档

javascript完美拖拽的实现方法_javascript技巧

javascript完美拖拽的实现方法_javascript技巧:HTML代码: 代码如下: 网站登录 用户名: 密 码: CSS代码: 代码如下:body, h2 { margin:0; padding:0;}#login { width:350px; height:250px; border:1px solid #ccc; position:absolute; left:512
推荐度:
导读javascript完美拖拽的实现方法_javascript技巧:HTML代码: 代码如下: 网站登录 用户名: 密 码: CSS代码: 代码如下:body, h2 { margin:0; padding:0;}#login { width:350px; height:250px; border:1px solid #ccc; position:absolute; left:512


HTML代码:
代码如下:











网站登录



用户名:


密 码:








CSS代码:
代码如下:
body, h2 {
margin:0;
padding:0;
}
#login {
width:350px;
height:250px;
border:1px solid #ccc;
position:absolute;
left:512px;
top:300px;
}
#login h2 {
font-size:14px;
text-align:center;
height:30px;
line-height:30px;
background:#f60;
color:white;
cursor:move;
margin-bottom:30px;
letter-spacing:1px;
}
#login .user, #login .pass {
text-align:center;
font-size:12px;
height:60px;
line-height:40px;
}
#login .txt {
width:200px;
border:1px solid #ccc;
background:#fff;
height:30px;
line-height:30px;
}
#login .submit {
text-align:right;
}
#login .button {
width:100px;
height:30px;
background:#06f;
border:none;
cursor:pointer;
margin:10px 30px;
color:white;
letter-spacing:1px;
font-weight:bold;
}

拖拽核心代码:
代码如下:
function drag(obj) {
if (typeof obj === 'string') {
var obj = document.getElementById(obj);
} else {
var obj = obj;
}
function fixEvent(event) {
event.target = event.srcElement;
event.preventDefault = fixEvent.preventDefault;
return event;
}
fixEvent.preventDefault = function () {
this.returnValue = false;
};
obj.onmousedown = mousedown;
function mousedown(e) {
var e = e || fixEvent(window.event);
var disX = e.clientX - obj.offsetLeft;
var disY = e.clientY - obj.offsetTop;
if (e.target.tagName === 'H2') {
document.onmousemove = move;
document.onmouseup = up;
} else {
document.onmousemove = null;
document.onmouseup = null;
}
function move(e) {
var e = e || fixEvent(window.event);
var left = e.clientX - disX;
var top = e.clientY - disY;
if (obj.setCapture) {
obj.setCapture();
}
if (left < 0) {
left = 0;
} else if (left > document.documentElement.clientWidth - obj.offsetWidth) {
left = document.documentElement.clientWidth - obj.offsetWidth;
}
if (top < 0) {
top = 0;
} else if (top > document.documentElement.clientHeight - obj.offsetHeight) {
top = document.documentElement.clientHeight - obj.offsetHeight;
}
obj.style.left = left + 'px';
obj.style.top = top + 'px';
return false;
};
function up() {
if (obj.releaseCapture) {
obj.releaseCapture();
}
document.onmousemove = null;
document.onmouseup = null;
}
};
}

调用代码:
代码如下:
window.onload = function () {
var login = document.getElementById('login');
drag(login);
};

欢迎批评指正!!!

文档

javascript完美拖拽的实现方法_javascript技巧

javascript完美拖拽的实现方法_javascript技巧:HTML代码: 代码如下: 网站登录 用户名: 密 码: CSS代码: 代码如下:body, h2 { margin:0; padding:0;}#login { width:350px; height:250px; border:1px solid #ccc; position:absolute; left:512
推荐度:
标签: js 拖动 拖拽
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top