js simple drag.
2024-09-04 17:29:57
// by zhangxinxu welcome to visit my personal website http://www.zhangxinxu.com/
// zxx.drag v1.0 2010-03-23 å…ƒç´ çš„æ‹–æ‹½å®žçŽ° var params = {
left: 0,
top: 0,
currentX: 0,
currentY: 0,
flag: false
};
//获å–相关CSS属性
var getCss = function(o,key){
return o.currentStyle? o.currentStyle[key] : document.defaultView.getComputedStyle(o,false)[key];
}; //拖拽的实现
var startDrag = function(bar, target, callback){
if(getCss(target, "left") !== "auto"){
params.left = getCss(target, "left");
}
if(getCss(target, "top") !== "auto"){
params.top = getCss(target, "top");
}
//o是移动对象
bar.onmousedown = function(event){
params.flag = true;
if(!event){
event = window.event;
//防æ¢IEæ–‡å—选ä¸
bar.onselectstart = function(){
return false;
}
}
var e = event;
params.currentX = e.clientX;
params.currentY = e.clientY;
};
document.onmouseup = function(){
params.flag = false;
if(getCss(target, "left") !== "auto"){
params.left = getCss(target, "left");
}
if(getCss(target, "top") !== "auto"){
params.top = getCss(target, "top");
}
};
document.onmousemove = function(event){
var e = event ? event: window.event;
if(params.flag){
var nowX = e.clientX, nowY = e.clientY;
var disX = nowX - params.currentX, disY = nowY - params.currentY;
target.style.left = parseInt(params.left) + disX + "px";
target.style.top = parseInt(params.top) + disY + "px";
} if (typeof callback == "function") {
callback(parseInt(params.left) + disX, parseInt(params.top) + disY);
}
}
};
最新文章
- 微信支付开发(1) JS API支付
- 用java代码手动控制kafkaconsumer偏移量
- Slave2: no datanode to stop(HADOOP_PID_DIR)
- Potocol Buffer详解
- PHP高级笔记汇总
- 【转载】Apache kafka原理与特性(0.8V)
- laravel post请求失败
- Courses(最大匹配)
- java中String是对象还是类?详解java中的String
- thinkphp获取特定字段的两种方法
- Vue 组件(component)之 精美的日历
- Canvas中绘制贝塞尔曲线
- arcgis raster clip and mask difference 栅格 提取 clip 和 mask 方法的区别
- 2018-01微信小程序--直播
- Centos6.5部署Rsyslog+cron+rsync备份服务器
- python自动化开发-8
- BAI度 内部资料!Python_Threads多线程
- 【x】 PAT/BasicLevel_C++/1002. 写出这个数 (20).cpp
- Oracle数据库日期格式转换操作
- java程序猿常用Linux命令