色婷婷狠狠18禁久久YY,CHINESE性内射高清国产,国产女人18毛片水真多1,国产AV在线观看

javascript 拖拽排序

javascript是一門強(qiáng)大的編程語(yǔ)言,它可以用來創(chuàng)造豐富的用戶界面和豐富的互聯(lián)網(wǎng)應(yīng)用程序。其中,拖拽排序是javascript中重要的部分之一。本文將向讀者介紹javascript拖拽排序的實(shí)現(xiàn)方法。

拖拽排序功能被廣泛應(yīng)用于網(wǎng)頁(yè)設(shè)計(jì)和互聯(lián)網(wǎng)應(yīng)用程序中。在網(wǎng)頁(yè)設(shè)計(jì)中,用戶可以通過拖拽元素的方式實(shí)現(xiàn)頁(yè)面重排,使得用戶界面更加美觀和直觀。在互聯(lián)網(wǎng)應(yīng)用程序中,拖拽排序常被用來改變列表或樹形節(jié)點(diǎn)的順序,從而達(dá)到更好的用戶體驗(yàn)。

// HTML代碼
  • Item 1
  • Item 2
  • Item 3
// javascript代碼 const list = document.getElementById('list'); let dragItem = null; list.addEventListener('dragstart', e =>{ dragItem = e.target; }); list.addEventListener('dragover', e =>{ e.preventDefault(); const afterElement = getDragAfterElement(list, e.clientY); const parent = list.parentElement; if (afterElement == null) { parent.appendChild(dragItem); } else { parent.insertBefore(dragItem, afterElement); } }); function getDragAfterElement(container, y) { const draggableElements = [...container.querySelectorAll('li:not(.dragging)')]; return draggableElements.reduce((closest, child) =>{ const box = child.getBoundingClientRect(); const offset = y - box.top - box.height / 2; if (offset< 0 && offset >closest.offset) { return { offset: offset, element: child }; } else { return closest; } }, { offset: Number.NEGATIVE_INFINITY }).element; }

以上是javascript實(shí)現(xiàn)拖拽排序的基本代碼。代碼中包含3個(gè)事件監(jiān)聽器:dragstart、dragover、dragend。其中,dragstart和dragend事件處理程序用于設(shè)置拖拽項(xiàng)并在拖拽結(jié)束時(shí)重置該項(xiàng)。dragover事件處理程序是最關(guān)鍵的,用于移動(dòng)拖拽項(xiàng)到目標(biāo)位置。

在上述代碼中,getDragAfterElement函數(shù)被用于確定拖拽項(xiàng)放入其父元素的哪個(gè)位置。在前面的if條件分支中,如果afterElement變量的值為null(即拖拽項(xiàng)已經(jīng)到達(dá)父元素的底部),則dragItem(即拖拽項(xiàng))被追加到parent元素中。否則,parent元素使用insertBefore方法將dragItem(即拖拽項(xiàng))插入到afterElement元素之前。

拖拽排序功能是實(shí)現(xiàn)動(dòng)態(tài)頁(yè)面交互的一種有效方法,可以為用戶提供更好的用戶體驗(yàn)。通過javascript編寫的拖拽排序功能易于實(shí)現(xiàn),且易于理解和修改。本文提供的javascript拖拽排序代碼可以在您的web應(yīng)用程序中靈活使用,以提高您的用戶體驗(yàn)和應(yīng)用程序的易用性。