[精讚] [會員登入]
1399

Jquery+CSS div區塊的拖拉(drag and drop)效果

網頁想要做到拖拉區塊的功能,但又不想使用他人的插件或是 jquery-ui的話,怎麼做?

分享此文連結 //n.sfs.tw/14873

分享連結 Jquery+CSS div區塊的拖拉(drag and drop)效果@新精讚
(文章歡迎轉載,務必尊重版權註明連結來源)
2020-12-29 12:59:04 最後編修
2020-12-22 13:27:33 By 張○○
 

自動目錄

網頁想要做到拖拉區塊的功能,但又不想使用他人的插件或是 jquery-ui的話,怎麼做?

此篇主要是參考 https://codepen.io/sun_kao/pen/DkFla 的範例修改,原範例的做法是物件用position:absolute此範例改position:fixed。

此功能主要是做個訊息框,只留下區塊的拖拉 drag and drop 的效果。

差別在於顯示的部分,margin-top 和 margin-left 有退縮 -200px。

HTML

<div id="centermsg" >
訊息欄 <div id="closemsg">X 關閉</div>
  <div id="msgbody">訊息本文
  </div>
</div>

CSS

#centermsg { 
   z-index:9999;
   position: fixed; 
   top:50%;
   left:50%; 
   margin-left:-200px; 
   margin-top:-200px; 
   background:black; 
   width:400px; 
   height:350px;
}
#msgbody { 
   background: black; 
   color:white;
}

說明

第3行 css的重點是 第三行position要設為絕對absolute或是固定fixed;

第6~7行 為了置中對齊,因此要退縮邊界為寬度的一半,就能置中。

JQUERY

var x,y,key;
$('#centermsg').bind({
    mousedown: function(event){
        var object = $(this).offset();
        x = event.pageX-object.left;
        y = event.pageY-object.top;
        key = true;  },
    mousemove: function (event){
        if(key){ $(this).css({'top':event.clientY-y+200, 'left':event.clientX-x+200 }); }},
    mouseup: function (){ key =false; }
});

說明:

第1行 設定外部變數,(x,y) 為滑鼠按下時在 <div id='centermsg'>中的相對位置,key 按下滑鼠mousedown啟動,mouseup時關閉移動的開關。

第5~6行 滑鼠位置- 左上角的位置取得按下時的div中相對位置

第9行 滑鼠在畫面上相對位置 - 相對位置 + 退縮的200 = 左上角的位置

 

參考資料

[1] https://codepen.io/sun_kao/pen/DkFla

 

 

END

你可能感興趣的文章

[jQuery] 利用load()來達成ajax的寫法 jQuery中利用load()來達成ajax的寫法,也有人稱他是假的ajax,作法就是..

[jQuery] textarea 的取值和給值 HTML 的 TEXTAREA 標籤若要用 jquery 取值,不能使用 .text() 或 .html() ,使用 .

[CKeditor4] 設定區塊樣式、段落格式、字型名稱及字型大小 CKeditor4中要自訂設定區塊樣式、段落格式、字型名稱及字型大小。

[Javascript] 陣列、陣列的操作 Javascript 的陣列操作:宣告、取值、賦值、插入或移除項目,檢查KEY、檢查是否為陣列等等

Jquery 圖片放大的工具:放大鏡 想讓網頁上的圖片局部放大,有沒有簡單好用的 jquery?

[Javascript] 偵錯方式 (火狐中的javascript偵錯) javascript 並不是很容易偵錯(debug)的語言,但那是以前,現在有很多瀏覽器支持很多的工具,此文以火狐為例談談偵錯...

我有話要說

>>

限制:留言最高字數1000字。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

使用Google尋找你的手機 這近發現google竟然可以用來找android的手機,而且不需要經過什麼設定或安裝軟體。

UTF-8 BOM (Byte Order Mark) 的問題 在 Michael Kaplan 那看到 Every character has a story #4: U+feff

安裝SPHINX支援中文 新版本的 sphinx 和舊版不同,網路上很多範例和教學是不能用的。此文是安裝和設定方法分享

為什麼要重造輪子? 什麼輪子?造什麼輪子?我為什麼要重造輪子?

世紀帝國征服者新版本--被遺忘的帝國 世紀帝國征服者新版本--被遺忘的帝國 世紀二代的征服者是精典遊戲中的精典,aofe更好玩...