js操作table中tr的順序?qū)崿F(xiàn)上移下移一行的效果
總體思路是在table外部加個(gè)div,修改div的innerHtml實(shí)現(xiàn)改變tr順序的效果
具體思路是
獲取當(dāng)前要移動(dòng)tr行的rowIndex,在table中刪除掉,然后循環(huán)table的rows,到了目標(biāo)行再直接加進(jìn)去,最后把整體的html賦值給div完成效果
js代碼如下
//使行向上一行
function setRowUp(obj) {
if (obj.parentNode.parentNode.rowIndex != 1) {
var tab = obj.parentNode.parentNode.parentNode;
var nowNodeInnerHtml = obj.parentNode.parentNode.innerHTML;
var nowNowIndex = obj.parentNode.parentNode.rowIndex;
tab.deleteRow(nowNowIndex);
var newHtml = "<table cellpadding=\"5\" cellspacing=\"0\">";
newHtml += ("<TR style='font-weight: bold; text-align: center;'>" + tab.rows[0].innerHTML + "</TR>");
for (i = 1; i < tab.rows.length; i++) {
if (i == (nowNowIndex - 1)) {
newHtml += ("<TR>" + nowNodeInnerHtml + "</TR>");
}
newHtml += ("<TR>" + tab.rows[i].innerHTML + "</TR>");
}
newHtml += "</table>";
document.getElementById("divContent").innerHTML = newHtml;
}
}
//使行向下一行
function setRowDown(obj) {
if (obj.parentNode.parentNode.rowIndex != (document.getElementById("divContent").childNodes[0].rows.length - 1)) {
var tab = obj.parentNode.parentNode.parentNode;
var nowNodeInnerHtml = obj.parentNode.parentNode.innerHTML;
var nowNowIndex = obj.parentNode.parentNode.rowIndex;
tab.deleteRow(nowNowIndex);
var newHtml = "<table cellpadding=\"5\" cellspacing=\"0\">";
newHtml += ("<TR style='font-weight: bold; text-align: center;'>" + tab.rows[0].innerHTML + "</TR>");
for (i = 1; i < tab.rows.length; i++) {
if (i == (nowNowIndex + 1)) {
newHtml += ("<TR>" + nowNodeInnerHtml + "</TR>");
}
newHtml += ("<TR>" + tab.rows[i].innerHTML + "</TR>");
}
//向下可能到表格現(xiàn)有行數(shù)外 額外處理
if (tab.rows.length == (nowNowIndex + 1)) {
newHtml += ("<TR>" + nowNodeInnerHtml + "</TR>");
}
newHtml += "</table>";
document.getElementById("divContent").innerHTML = newHtml;
}
}
測試html代碼如下
<body>
<div id="divContent">
<table cellpadding="5" cellspacing="0">
<tr style='font-weight: bold; text-align: center;'><td>工號(hào)</td><td>姓名</td></tr>
<tr><td>0001
<input type="button" value="↑" onclick="setRowUp(this)" />
<input type="button" value="↓" onclick="setRowDown(this)" />
</td><td>姓名01</td></tr>
<tr><td>0002
<input type="button" value="↑" onclick="setRowUp(this)" />
<input type="button" value="↓" onclick="setRowDown(this)" />
</td><td>姓名02</td></tr>
<tr><td>0003
<input type="button" value="↑" onclick="setRowUp(this)" />
<input type="button" value="↓" onclick="setRowDown(this)" />
</td><td>姓名03</td></tr>
<tr><td>0004
<input type="button" value="↑" onclick="setRowUp(this)" />
<input type="button" value="↓" onclick="setRowDown(this)" />
</td><td>姓名04</td></tr>
<tr><td>0005
<input type="button" value="↑" onclick="setRowUp(this)" />
<input type="button" value="↓" onclick="setRowDown(this)" />
</td><td>姓名05</td></tr>
</table>
</div>
</body>
總結(jié)
以上所述是小編給大家介紹的js操作table中tr的順序?qū)崿F(xiàn)上移下移一行的效果,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
- 基于js實(shí)現(xiàn)數(shù)組相鄰元素上移下移
- JS與jQuery實(shí)現(xiàn)ListBox上移,下移,左移,右移操作功能示例
- js實(shí)現(xiàn)數(shù)組內(nèi)數(shù)據(jù)的上移和下移的實(shí)例
- Vue.js實(shí)現(xiàn)一個(gè)todo-list的上移下移刪除功能
- AngularJS實(shí)現(xiàn)數(shù)據(jù)列表的增加、刪除和上移下移等功能實(shí)例
- JS實(shí)現(xiàn)的表格操作類詳解(添加,刪除,排序,上移,下移)
- js實(shí)現(xiàn)Select列表各項(xiàng)上移和下移的方法
- JS實(shí)現(xiàn)點(diǎn)擊上移下移LI行數(shù)據(jù)的方法
- JS實(shí)現(xiàn)一個(gè)列表中包含上移下移刪除等功能
- js實(shí)現(xiàn)按鈕進(jìn)行某行上移下移
相關(guān)文章
JavaScript實(shí)現(xiàn)瀏覽器網(wǎng)頁自動(dòng)滾動(dòng)并點(diǎn)擊的示例代碼
這篇文章主要介紹了JavaScript實(shí)現(xiàn)瀏覽器網(wǎng)頁的自動(dòng)滾動(dòng)并點(diǎn)擊的示例代碼,幫助大家更好的理解和學(xué)習(xí)JavaScript的使用,感興趣的朋友可以了解下2020-12-12
JS操作字符串轉(zhuǎn)換為數(shù)值并取整的代碼
這篇文章主要介紹了JS操作字符串轉(zhuǎn)換為數(shù)值并取整的代碼,代碼比較短,需要的朋友可以參考下2014-01-01
微信小程序網(wǎng)絡(luò)請(qǐng)求的封裝與填坑之路
本文主要介紹了關(guān)于小程序網(wǎng)絡(luò)請(qǐng)求的封裝的相關(guān)資料。具有很好的參考價(jià)值。下面跟著小編一起來看下吧2017-04-04

