一個非常簡單的例子,體驗效果:http:///keleyi/phtml/jqtexiao/29.htm
以下是完整代碼,保存到HTML文件打開也可以體驗效果。
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<title>jQuery 版“元素拖拽改變大小”原型 </title>
<script type="text/javascript" src="http:///keleyi/pmedia/jquery/jquery-1.11.1.min.js"></script>
<script type="text/javascript">
/*
* jQuery.Resize
* Date: 2014-12-04
* http:///
*/
$(function () {
//綁定需要拖拽改變大小的元素對象
bindResize(document.getElementById('kel'+'eyi'));
});
function bindResize(el) {
//初始化參數
var els = el.style,
//鼠標的 X 和 Y 軸坐標
x = y = 0;
//邪惡的食指
$(el).mousedown(function (e) {
//按下元素後,計算當前鼠標與對象計算後的坐標
x = e.clientX - el.offsetWidth,
y = e.clientY - el.offsetHeight;
//在支持 setCapture 做些東東
el.setCapture ? (
//捕捉焦點
el.setCapture(),
//設置事件
el.onmousemove = function (ev) {
mouseMove(ev || event)
},
el.onmouseup = mouseUp
) : (
//綁定事件
$(document).bind("mousemove", mouseMove).bind("mouseup", mouseUp)
)
//防止默認事件發生
e.preventDefault()
});
//移動事件
function mouseMove(e) {
//宇宙超級無敵運算中...
els.width = e.clientX - x + 'px',
els.height = e.clientY - y + 'px'
}
//停止事件
function mouseUp() {
//在支持 releaseCapture 做些東東
el.releaseCapture ? (
//釋放焦點
el.releaseCapture(),
//移除事件
el.onmousemove = el.onmouseup = null
) : (
//卸載事件
$(document).unbind("mousemove", mouseMove).unbind("mouseup", mouseUp)
)
}
}
</script>
<style type="text/css">
#keleyi{
position:absolute;
top:0;left:0;
width:200px;
height:100px;
background:#f1f1f1;
text-align:center;
line-height:16px;
border:1px solid #CCC;
cursor:move;
}
</style>
</head>
<body>
<div id="keleyi">:請按住本灰色區域並拖拽.<a href="http:///a/bjad/yy8jnwqj.htm" target="_blank">原文</a>.本效果支持各種浏覽器,入Chrome,FireFox,IE,Opera等</div>
</body>
</html>