JS HTML5實現拖拽移動列表效果
來源:易賢網 閱讀:1574 次 日期:2016-07-26 15:32:37
溫馨提示:易賢網小編為您整理了“JS HTML5實現拖拽移動列表效果”,方便廣大網友查閱!

這篇文章主要為大家詳細介紹了JS HTML5實現拖拽移動列表效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下

HTML5拖拽移動列表實現思路:

1.循環(huán)設置每個子項的draggable屬性,以及設置拖動標記(不會多個或全部子項都移動)

2.每次進入投放區(qū),則檢測時候有拖放標記,有則添加dom元素,以此類推

另一種實現思路是:可以利用拖放中DataTransfer對象作為屬性,用setData()和getData()方法傳遞每個拖動的子項的id等數據,找到指定的子項進行移動….待實驗。。。

HTML:

//空列表

<div id="box"></div>

//內容列表

<ul id="con">

 <li>第1項</li>

 <li>第2項</li>

 <li>第3項</li>

 <li>第4項</li>

</ul>

JS:

<script>

function $(id) {

return document.getElementById(id);

}

var con = $("con");

var box = $("box");

var liDoms = document.getElementsByTagName("li");

var i = 0,

len = liDoms.length;

//循環(huán)設置每個子項的draggable屬性,以及時候拖動標記

for (; i < len; i += 1) {

liDoms[i].draggable = 'true';

liDoms[i].flag = false;

liDoms[i].ondragstart = function() {

this.flag = true;

};

liDoms[i].ondragend = function() {

this.flag = false;

};

}

//投放區(qū)事件

$("box").ondragenter = function(e) {

e.preventDefault();

console.log('進入');

};

$("box").ondragover = function(e) {

e.preventDefault();

console.log('移動');

};

$("box").ondragleave = function(e) {

e.preventDefault();

console.log('離開');

};

$("box").ondrop = function(e) {

e.preventDefault();

for (var i = 0; i < liDoms.length; i += 1) {

if (liDoms[i].flag) {

box.appendChild(liDoms[i]);

}

}

console.log('成功');

};

//投放區(qū)事件

$("con").ondragenter = function(e) {

e.preventDefault();

console.log('進入');

};

$("con").ondragover = function(e) {

e.preventDefault();

console.log('移動');

};

$("con").ondragleave = function(e) {

e.preventDefault();

console.log('離開');

};

$("con").ondrop = function(e) {

e.preventDefault();

for (var i = 0; i < liDoms.length; i += 1) {

if (liDoms[i].flag) { //此時獲得是時box對象下li,而不是原容器的li了

$("con").appendChild(liDoms[i]);

}

}

console.log('成功');

};

</script>

以上就是本文的全部內容,希望對大家的學習有所幫助。

更多信息請查看網絡編程
易賢網手機網站地址:JS HTML5實現拖拽移動列表效果

2026國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯系我們 | 人才招聘 | 網站聲明 | 網站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網