[精讚] [會員登入]
38

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

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

此文完整連結 http://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

 

 

你可能感興趣的文章

正則表達式:Email名稱防止連續輸入點(.)及下底線(_) Email的名稱中要允許特殊符號,但又不允許連續出現的正則表達式

[jQuery] checkbox 及 radio 設定值 jQuery 之 checkbox 及 radio 取值及設定值的方法

[Jquery] 複選的checkbox取值 遇到複選的checkbox該如何取值?

[jQuery] select 元件的取值及給值 html中的元件select,在jquery中要如何使用?

[CKeditor4] 修改調色盤 修改ckeditor預設的調色盤

[Javascript/Jquery] 移除textarea中空行、空白行。 textarea中要移除沒內容的空行、只有空白的行、只有定位字元的行

Javascript/Jquery 建立、讀取、刪除cookie值 Javascript/Jquery 建立、讀取、刪除cookie值

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

[Ckeditor4] 讀、寫與插入內容到欄位 Ckeditor4 提供非常多方法,可以插入、讀取和寫入到TEXTAREA中

[CKeditor4] 修改特殊字元 CKeditor4 中設定自己想用的特殊字元

我有話要說


限制:留言最高字數1000字,超過部分會被截掉。請注意:留言不可帶有網址,會被濾掉。 限制:未登入訪客,每則留言間隔需超過10分鐘,每日最多5則留言。

訪客留言

[無留言]

隨機好文

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

為什麼要買長達二十年的保單? 為什麼要買長達二十年的保單?找一個可以說服我買二十年保單的理由。

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

[札記] 2016.7~12月札記 札記,只是札記

[NetBeans] 使用git複製別人的專案 NetBeans使用git複製別人的專案及版本控制