[精讚] [會員登入]
320

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

 

 

你可能感興趣的文章

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

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

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

Jquery+CSS div區塊的拖拉(drag and drop)效果 網頁想要做到拖拉區塊的功能,但又不想使用他人的插件或是 jquery-ui的話,怎麼做?

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

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

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

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

[Bootstrap] Datepicker使用/Bootstrap日期選日期選擇器的使用 Bootstrap日期選日期選擇器的使用

[Javascript] NaN是什麼? javascript 的NaN和取得整數

我有話要說


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

訪客留言

[無留言]

隨機好文

[Freebsd] 使用 ADSL 撥接上網 Freebsd上要使用 ADSL 撥接上網,該如何設定?

UTF-8的網頁但IE8一片空白 UTF8編碼的網頁在Firefox 正常顯示、但IE8 就是空白,IE8編碼設定是「自動偵測」可是自動偵測到的是 big5...

[PHP] 檢查IP是否在某個網段內 mtachcidr 要檢查IP是否在某個網段內,要寫幾行?10行?5行? 不用,只要2行。以下是我寫的 code /** * matchCI

[CodeIgniter 3] 資料庫的使用方法整理2/2 CI3 承襲 CI2,有很多的builder class可以用,依各人的使用習慣,有人喜歡一堆sql字串,有人喜歡用helper

問問題 問問題其實內涵很深,我悟了很久才懂。 有人問題的目的並不一定是想要得到答案,有時只是純粹想問問題..