PHP+jQuery實(shí)現(xiàn)隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置
想拖動(dòng)頁面上的層,完全可以用jQuery ui的Draggable方法來實(shí)現(xiàn),那如何將拖動(dòng)后層的位置保存下來呢?本文將給出答案。本文講解了如何采用PHP+MySQL+jQuery,實(shí)現(xiàn)隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置。
之前我有文章:,文中以項(xiàng)目為示例,講解了實(shí)現(xiàn)拖動(dòng)布局的方法。本文與之不同之處在于可以任意拖動(dòng)頁面位置,原理就是通過拖動(dòng)將拖動(dòng)后層的相對位置left,top和z-index三個(gè)參數(shù)更新到數(shù)據(jù)表中對應(yīng)的記錄,頁面通過CSS解析每個(gè)層不同的位置。請看具體實(shí)現(xiàn)步驟。
準(zhǔn)備MySQL數(shù)據(jù)表
首先需要準(zhǔn)備一張表notes,用來記錄層的內(nèi)容,背景色和坐標(biāo)等信息。
CREATE TABLE IF NOT EXISTS `notes` ( `id` int(11) NOT NULL auto_increment, `content` varchar(200) NOT NULL, `color` enum('yellow','blue','green') NOT NULL default 'yellow', `xyz` varchar(100) default NULL, PRIMARY KEY (`id`) ) ENGINE=MyISAM DEFAULT CHARSET=utf8;
然后向表中插入幾條記錄,注意xyz字段表示的是層的xyz坐標(biāo)的組合,格式為"x|y|z"。
drag.php
在drag.php中,需要讀取notes表中的記錄,顯示在drag.php頁面中,代碼如下:
include_once('connect.php'); //鏈接數(shù)據(jù)庫 $notes = ''; $left=''; $top=''; $zindex=''; $query = mysql_query("select * from notes order by id desc"); while($row=mysql_fetch_array($query)){ list($left,$top,$zindex) = explode('|',$row['xyz']); $notes.= ' <div class="note '.$row['color'].'" style="left:'.$left.'px;top:'.$top.'px;z-index:' .$zindex.'"> <span class="data">'.$row['id'].'.</span>'.htmlspecialchars($row['content']).' </div>'; }
然后將讀取出來的$notes現(xiàn)在在div中。
<div class="demo"> <?php echo $notes;?> </div>
注意,我在生成的每個(gè)DIV.note中定義了位置,即設(shè)置該div的left,top和z-index值。
CSS
.demo{position:relative; height:500px; margin:20px; border:1px dotted #d3d3d3} .note{width:150px; height:150px; position:absolute; margin-top:150px; padding:10px; overflow:hidden; cursor:move; font-size:16px; line-height:22px;} .note span{margin:2px} .yellow{background-color:#FDFB8C;border:1px solid #DEDC65;} .blue{background-color:#A6E3FC;border:1px solid #75C5E7;} .green{background-color:#A5F88B;border:1px solid #98E775;}
有了樣式之后,然后運(yùn)行drag.php,這時(shí)就可以看到頁面中排列的的幾個(gè)層,但是還不能拖動(dòng),因?yàn)檫€要加入jQuery。
jQuery
首先需要載入jquery庫和jquery-ui插件以及global.js。
<script type="text/javascript" src="js/jquery.js"></script> <script type="text/javascript" src="js/jquery-ui.min.js"></script>
然后再global.js加入代碼:
$(function(){ var tmp; $('.note').each(function(){ tmp = $(this).css('z-index'); if(tmp>zIndex) zIndex = tmp; }) make_draggable($('.note')); }); var zIndex = 0;
global.js中,首先在$(function()里定義了一個(gè)變量tmp,通過判斷每個(gè)div.note的z-index值,保證拖動(dòng)時(shí),該DIV在最上層(即z-index為最大值),就是不會(huì)被別的層覆蓋。
并且設(shè)置zIndex的初始值為0。
接下來,寫了一個(gè)函數(shù)make_draggable();該函數(shù)調(diào)用jquery ui插件的Draggable方法,處理拖動(dòng)范圍,透明度及拖動(dòng)停止后執(zhí)行的更新操作。
function make_draggable(elements){ elements.draggable({ opacity: 0.8, containment:'parent', start:function(e,ui){ ui.helper.css('z-index',++zIndex); }, stop:function(e,ui){ $.get('update_position.php',{ x : ui.position.left, y : ui.position.top, z : zIndex, id : parseInt(ui.helper.find('span.data').html()) }); } }); }
當(dāng)拖動(dòng)時(shí),將當(dāng)前層的z-index屬性設(shè)置為最大值,即保證當(dāng)前層在最上面,不被其他層覆蓋,并且設(shè)置了拖動(dòng)范圍和透明度,當(dāng)停止拖動(dòng)時(shí),向后臺(tái)update_position.php發(fā)送一個(gè)ajax請求,傳遞的參數(shù)有x,y,z和id的值。接下來我們來看update_position.php的處理。
update_position.php保存拖動(dòng)位置
update_position.php需要做的是,獲取前臺(tái)通過ajax請求發(fā)來的數(shù)據(jù),更新數(shù)據(jù)表中相應(yīng)的字段內(nèi)容。
include_once('connect.php'); if(!is_numeric($_GET['id']) || !is_numeric($_GET['x']) || !is_numeric($_GET['y']) || !is_numeric($_GET['z'])) die("0"); $id = intval($_GET['id']); $x = intval($_GET['x']); $y = intval($_GET['y']); $z = intval($_GET['z']); mysql_query("UPDATE notes SET xyz='".$x."|".$y."|".$z."' WHERE id=".$id); echo "1";
以上所述就是本文的全部內(nèi)容了,希望大家能夠喜歡。
- jquery拖動(dòng)層效果插件用法實(shí)例分析(附demo源碼)
- PHP+MySQL+jQuery隨意拖動(dòng)層并即時(shí)保存拖動(dòng)位置實(shí)例講解
- jQuery 拖動(dòng)層(在可視區(qū)域范圍內(nèi))
- jquery sortable的拖動(dòng)方法示例詳解
- jquery div拖動(dòng)效果示例代碼
- 利用JQuery+EasyDrag 實(shí)現(xiàn)彈出可拖動(dòng)的Div,同時(shí)向Div傳值,然后返回Div選中的值
- 基于jquery的鼠標(biāo)拖動(dòng)效果代碼
- jQuery實(shí)現(xiàn)鼠標(biāo)可拖動(dòng)調(diào)整表格列寬度
- jquery簡單的拖動(dòng)效果實(shí)現(xiàn)原理及示例
- jquery實(shí)現(xiàn)鼠標(biāo)拖動(dòng)圖片效果示例代碼
- jquery實(shí)現(xiàn)的鼠標(biāo)拖動(dòng)排序Li或Table
- jQuery實(shí)現(xiàn)的簡單拖動(dòng)層示例
相關(guān)文章
jquery實(shí)現(xiàn)帶單選按鈕的表格行選中時(shí)高亮顯示
如果將選中的這條記錄的行高亮顯示,同時(shí)該行的單選按鈕也被選中了,這樣會(huì)提高用戶的體驗(yàn)的,于是本文下了個(gè)示例,有需要的朋友可以參考下2013-08-08Jquery跨瀏覽器文本復(fù)制插件Zero Clipboard的使用方法
這篇文章主要介紹了Jquery跨瀏覽器文本復(fù)制插件Zero Clipboard的使用方法,需要的朋友可以參考下2016-02-02jQuery藍(lán)色風(fēng)格滑動(dòng)導(dǎo)航欄代碼分享
這篇文章主要為大家詳細(xì)介紹了jQuery藍(lán)色風(fēng)格滑動(dòng)導(dǎo)航欄特效,實(shí)現(xiàn)滑塊跟隨鼠標(biāo)左右滑動(dòng),簡單、時(shí)尚、大方,有需要的小伙伴可以參考下2015-08-08jquery彈出框插件jquery.ui.dialog用法分析
這篇文章主要介紹了jquery彈出框插件jquery.ui.dialog用法,結(jié)合實(shí)例形式分析了彈出框插件jquery.ui.dialog的功能、下載、使用方法與相關(guān)注意事項(xiàng),需要的朋友可以參考下2016-08-08jQuery formValidator表單驗(yàn)證插件開源了 含API幫助、源碼、示例
ajaxValidator函數(shù)在提交后發(fā)生錯(cuò)誤,停留在本頁面后,再次觸發(fā)校驗(yàn)會(huì)讓提示內(nèi)容一直處于onload狀態(tài)。2008-08-08jQuery插件slides實(shí)現(xiàn)無縫輪播圖特效
Slides – 是一個(gè)簡單的,容易定制和風(fēng)格化,的jQuery幻燈片插件。Slides提供褪色或幻燈片過渡效果,圖像淡入淡出,圖像預(yù)壓,自動(dòng)生成分頁,循環(huán),自動(dòng)播放的自定義等很多選項(xiàng)。用Slides插件,你可以隨機(jī)播放幻燈片,設(shè)定那一套您想要開始幻燈片。2015-04-04Jquery 數(shù)組操作大全個(gè)人總結(jié)
jQuery的數(shù)組處理,便捷,功能齊全. 最近的項(xiàng)目中用到的比較多,最近時(shí)間緊迫,今天抽了些時(shí)間回過頭來看 jQuery中文文檔順便對jQuery數(shù)組做個(gè)總結(jié)2013-11-11Jquery on方法綁定事件后執(zhí)行多次的解決方法
下面小編就為大家?guī)硪黄狫query on方法綁定事件后執(zhí)行多次的解決方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06模擬jQuery中的ready方法及實(shí)現(xiàn)按需加載css,js實(shí)例代碼
這篇文章介紹了模擬jQuery中的ready方法及實(shí)現(xiàn)按需加載css,js實(shí)例代碼,有需要的朋友可以參考一下2013-09-09