JS滑鼠事件完成元素拖拽(簡單-高階)
JS初學者記錄利用滑鼠事件完成元素在頁面中的拖拽
給入一個簡單div,設定樣式,完成div在頁面中的拖拽
<style>
div{
width:50px;
height:50px;
background-color:red;
position:absolute;
}
</style>
<div></div>
第一種:極簡單版本,下面為JS程式碼
<script>
var div = document.querySelector("div");
//按下時開始監聽在文件中滑鼠移動的事件
div.onmousedown = function (e1) {
// 當滑鼠在文件移動時,不能再div上移動,因為滑鼠可能離開div,造成無法拖拽
document.onmousemove = function (e) {
// 當滑鼠移動時,將當前滑鼠相對視口的座標賦值給元素的left和top
// 因為我們需要在按下的位置拖拽,因此我們還需要獲取按下鍵滑鼠相對div的左上角位置
// 使用當前滑鼠位置減去這個相對元素的左上角位置,保證滑鼠所按位置拖拽
div.style.left = e.clientX - e1.offsetX + "px";
div.style.top = e.clientY - e1.offsetY + "px";
}
// 當釋放滑鼠鍵時,刪除滑鼠移動事件和刪除滑鼠釋放事件
document.onmouseup = function (e) {
document.onmousemove = null;
document.onmouseup = null;
}
}
</script>
第二種:簡單版本
<script>
var div=document.querySelector("div");
var offsetX,offsetY;
div.addEventListener("mousedown",mouseDownHandler);
function mouseDownHandler(e){
offsetX=e.offsetX;
offsetY=e.offsetY;
//按下時開始監聽在文件中滑鼠移動的事件
document.addEventListener("mousemove",mousemoveHandler);
document.addEventListener("mouseup",mouseUpHandler);
}
function mousemoveHandler(e){
// 用當前滑鼠位置減去這個相對元素的左上角位置,保證滑鼠所按位置拖拽
div.style.left = e.clientX - offsetX + "px";
div.style.top = e.clientY - offsetY + "px";
}
// 當釋放滑鼠鍵時,刪除滑鼠移動事件和刪除滑鼠釋放事件
function mouseUpHandler(e){
document.removeEventListener("mousemove",mousemoveHandler);
document.removeEventListener("mouseup",mouseUpHandler);
}
</script>
第三種:簡單升級版
<script>
var div = document.querySelector("div");
var offsetX, offsetY;
div.addEventListener("mousedown", mouseHandler);
function mouseHandler(e) {
if (e.type === "mousedown") {
offsetX = e.offsetX;
offsetY = e.offsetY;
document.addEventListener("mousemove", mouseHandler);
document.addEventListener("mouseup", mouseHandler);
} else if (e.type === "mousemove") {
// 用當前滑鼠位置減去這個相對元素的左上角位置,保證滑鼠所按位置拖拽
div.style.left = e.clientX - offsetX + "px";
div.style.top = e.clientY - offsetY + "px";
} else if (e.type === "mouseup") {
// 當釋放滑鼠鍵時,刪除滑鼠移動事件和刪除滑鼠釋放事件
document.removeEventListener("mousemove", mouseHandler);
document.removeEventListener("mouseup", mouseHandler);
}
}
</script>
第四種:中級版本 拖拽多個元素時
<script>
var divs = document.querySelectorAll("div");
// 給每一個div元素新增滑鼠按下事件
for (i = 0; i < divs.length; i++) {
divs[i].addEventListener("mousedown", mouseHandler);
}
function mouseHandler(e) {
if (e.type === "mousedown") {
//取消預設事件
e.preventDefault();
//this為點選的目標元素
document.div = this;
document.offset = { x: e.offsetX, y: e.offsetY };
document.addEventListener("mousemove", mouseHandler);
document.addEventListener("mouseup", mouseHandler);
} else if (e.type === "mousemove") {
//這裡的this就是執行偵聽事件的物件,也就是document,document.div就是點選的目標元素
// this.div.style.left = e.clientX - document.offset.x + "px";
// this.div.style.top = e.clientY - document.offset.y + "px";
// 用當前滑鼠位置減去這個相對元素的左上角位置,保證滑鼠所按位置拖拽
document.div.style.left = e.clientX - document.offset.x + "px";
document.div.style.top = e.clientY - document.offset.y + "px";
} else if (e.type === "mouseup") {
document.removeEventListener("mousemove", mouseHandler);
document.removeEventListener("mouseup", mouseHandler);
}
}
</script>
第五種:高階版本,把事件函式封裝在一個物件裡面,使用時直接填入引數呼叫;下面程式碼為封裝好的函式
var Utils=(function(){
// 封裝版的拖拽
// 不能再容器內拖拽
return {
dragOn(elem){
elem.self=this;
elem.addEventListener("mousedown",this.mouseHandler);
},
dragOff(elem){
elem.addEventListener("mousdown",this.mouseHandler);
},
mouseHandler(e){
if(e.type==="mousedown"){
e.preventDefault();
document.div=e.target;
document.offset={x:e.offsetX,y:e.offsetY};
document.self=this.self;
document.addEventListener("mousemove",this.self.mouseHandler);
document.addEventListener("mouseup",this.self.mouseHandler);
}else if(e.type==="mousemove"){
document.div.style.left=e.clientX-document.offset.x+"px";
document.div.style.top=e.clientY-document.offset.y+"px";
}else if(e.type==="mouseup"){
// this document
document.removeEventListener("mousemove",document.self.mouseHandler)
document.removeEventListener("mouseup",document.self.mouseHandler)
}
}
}
})();
執行時呼叫封裝好的函式填入引數即可
<script src="./js/Utils.js"></script>
給divs裡面給個div都呼叫一次封裝好的函式,這樣就可以拖拽每個div元素
var divs=document.querySelectorAll("div");
for(var i=0;i<divs.length;i++){
Utils.dragOn(divs[i]);
}
第六種:終極版本,老師沒教。
相關文章
- 滑鼠拖拽事件事件
- 事件 滑鼠事件 表單事件 from表單事件
- 高階函式簡述 js函式JS
- JS高階技巧(簡潔版)JS
- js拖拽原理及簡單實現(渣渣自學)JS
- 拖拽一個元素如此簡單,mouse、drag、touch三兄弟的用處
- js高階JS
- js--事件流、事件委託、事件階段JS事件
- 舉例說明js滑鼠事件有哪些?JS事件
- 簡單事件事件
- 單擊滑鼠即可完成的檔案共享
- Js高階APIJSAPI
- JS高階三JS
- 對高階函式的簡單認識函式
- drag &drop 拖拽事件事件
- drag & drop 拖拽事件事件
- 滑鼠事件事件
- JS高階程式設計第3章--精簡版JS程式設計
- JS高階程式設計第2章--精簡版JS程式設計
- js拖拽技能JS
- pixi.js 簡單互動事件(點選、縮放、平移)JS事件
- 同一個元素的單擊事件與雙擊事件事件
- HTML元素設定可拖拽HTML
- <svg>元素簡單介紹SVG
- 9.移除元素(簡單)
- JS給全域性繫結事件以及給除某個元素外的其他元素繫結事件JS事件
- 02--JS02--高階JS
- js高階之-new map()JS
- .NETCore 簡單且高階的庫 csredis v3.0.0NetCoreRedis
- angualr實現滑鼠拖拽排序功能排序
- 用JS點選事件做一個簡單的計算器JS事件
- 原生JS實現隨著滑鼠滾動到元素位置觸發對應css3動畫,簡單易用滾動監測JSCSSS3動畫
- 原生JS拖拽效果JS
- JavaScript元素拖拽路徑回放效果JavaScript
- 高階單例模式單例模式
- socket 完成簡單的通訊
- 監聽滑鼠事件事件
- 滑鼠、鍵盤事件事件