jQuery利用鍵盤上下鍵移動表格內容
本文實例為大家分享了jQuery利用鍵盤上下鍵移動表格內容的具體代碼,供大家參考,具體內容如下
在我們編輯表格內容時,經常需要將表格內容的位置進行移動,而利用鍵盤上下鍵進行移動是十分方便的。
效果如下:
基本原理是:先使用鼠標選中其中的一行,隨后使用鍵盤上下鍵,通過獲取不同的鍵值區(qū)分上移和下移的操作,隨后首先交換兩行的編號,隨后交換兩行的內容,保證了兩行內容移動而編號不改變。
下面是代碼:
function clickA(obj){ ? ? ? ? ? ? currentLine=$.trim($(obj).find("td:first-child").html()); ? ? ?? ? ? ? ? $('#table1 tr').each(function () { $(this).css("background-color", "white"); }); ? ? ? ? //將所有行變?yōu)榘咨? ? ? ? ? $('#line' + currentLine).each(function () { $(this).css("background-color", "red"); }); ? ? ? ? //將當前行變?yōu)榧t色 ? ? ? ?? ? ? ? ? ? //獲取當前行數(shù)? }
以上為鼠標的點擊一行的操作,獲取當前的行數(shù),以及將當前行變?yōu)榧t色。
<tr id=\"line"+num+"\" onclick='clickA(this)'></tr>
這個表格每一行的點擊事件綁定。
?$(document).keydown(function(event){ ? ? ? ? ? ? ? if(event.keyCode == 38){ ? ? ? ? ? ? ? //鍵盤上鍵 ? ? ? ? ? ? ?up_exchange_line(); ? ? ? ? ? }else if (event.keyCode == 40){ ?? ? ? ? ? ? ? down_exchange_line(); ? ? ? ? ? ? //鍵盤下鍵 ? ? ? ? ? } ? ? ? });
這個是獲取撲捉鍵盤上下鍵動作,進行不同的操作
function up_exchange_line(index) { ? ? ? ? if(currentLine != null && currentLine!= " "){ ? ? ? ? ? ? nowrow = currentLine; ? ? ? ? ? ? //獲取當前行 ? ? ? ? }else if (index != null) { ? ? ? ? ? ? nowrow = $.trim($(index).parent().parent().find("td:first-child").html()); ? ? ? ? } ? ? ? ? if (nowrow == 0) { ? ? ? ? ? ? alert('請點擊一行'); ? ? ? ? ? ? return false; ? ? ? ? ? ? //未點擊,無當前行要求用戶點擊一行 ? ? ? ? } ? ? ? ? ? ? ? ? if (nowrow <= 1) { ? ? ? ? ? ? alert('已到達頂端!'); ? ? ? ? ? ? return false; ? ? ? ? ? ? //上移到頂端后提示 ? ? ? ? } ? ? ? ?? ? ? ? ? var up = nowrow - 1; ? ? ? ?//首先交換兩行序號 ? ? ? ? $('#line' + up + " td:first-child").html(nowrow); ? ? ? ? $('#line' + nowrow + " td:first-child").html(up); ? ? ? ? //變色 ? ? ? ? $('#table1 tr').each(function () { $(this).css("background-color", "white"); }); ? ? ? ? $('#line' + up).css("background-color", "red"); ; ? ? ? ? //獲取兩行的內容 ? ? ? ? var upContent = $('#line' + up).html(); ? ? ? ? var currentContent = $('#line' + nowrow).html(); ? ? ? ?//交換內容 ? ? ? ? $('#line' + up).html(currentContent); ? ? ? ? $('#line' + nowrow).html(upContent); ? ? ? ?? ? ? ? ? ? ? ?currentLine = up; ? ? ? ? ? ? ?//改變當前行,為繼續(xù)上移做準備 }
這個上移的方法,首先獲取當前行數(shù),隨后獲取上一行的行數(shù),首先進行序號的交換,隨后將當前行的紅色變至上一行,隨后交換所有的內容,最后更新當前行。這樣保證了,內容和當前所在行會跟這個鍵盤上鍵而移動而序號可以保持不變。
function down_exchange_line(index) { ? ? ? ? if(currentLine != null && currentLine != " "){ ? ? ? ? ? ? nowrow = currentLine; ? ? ? ? }else if (index != null) { ? ? ? ? ? ? nowrow = $.trim($(index).parent().parent().find("td:first-child").html()); ? ? ? ? } ? ? ? ? if (nowrow == 0) { ? ? ? ? ? ? alert('請選擇一項!'); ? ? ? ? ? ? return false; ? ? ? ? } ? ? ? ? maximum=$("#table1").find("tr").length ; ? ? ? ? if (nowrow >= maximum-1) { ? ? ? ? ? ? alert('已經是最后一項了!'); ? ? ? ? ? ? return false; ? ? ? ? } ? ? ? ? var dS = parseInt(nowrow) + 1; ? ? ? ? $('#line' + dS + " td:first-child").html(nowrow); ? ? ? ? $('#line' + nowrow + " td:first-child").html(dS); ? ? ? ? //變色 ? ? ? ? $('#table1 tr').each(function () { $(this).css("background-color", "white"); }); ? ? ? ? $('#line' + dS).css("background-color", "red");? ? ? ? ? //獲取兩行的內容 ? ? ? ? var nextContent = $('#line' + dS).html(); ? ? ? ? var currentContent = $('#line' + nowrow).html(); ? ? ? ? //交換內容 ? ? ? ? $('#line' + dS).html(currentContent); ? ? ? ? $('#line' + nowrow).html(nextContent); ? ? ?? ? ? ? ? if(dS>maximum-1){ ? ? ? ? ? ? currentLine=dS-1; ? ? ? ? }else{ ? ? ? ? ? ? ?currentLine = dS; ? ? ? ? } ? ? ? ?? }
同理,下降也是使用相同的方法,只不過是向下交換數(shù)據(jù)。
這樣基于jQuery使用鍵盤上下鍵交換表格內容的操作就完成了。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
jQuery簡單實現(xiàn)根據(jù)日期計算星期幾的方法
這篇文章主要介紹了jQuery簡單實現(xiàn)根據(jù)日期計算星期幾的方法,涉及jQuery針對日期時間簡單計算相關操作技巧,需要的朋友可以參考下2019-01-01基于Jquery代碼實現(xiàn)支持PC端手機端幻燈片代碼
支持PC端手機端幻燈片代碼是一款支持移動觸摸,支持鼠標拖拽切換,支持帶進度條的自動播放模式,本文給大家分享一款基于jquery代碼實現(xiàn)支持pc端手機端幻燈片代碼,感興趣的朋友一起學習吧2015-11-11jQuery彈出下拉列表插件(實現(xiàn)kindeditor的@功能)
這篇文章主要介紹了jQuery彈出下拉列表插件(實現(xiàn)kindeditor的@功能)的相關資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-08-08jQuery zclip插件實現(xiàn)跨瀏覽器復制功能
這篇文章主要介紹了jQuery zclip插件實現(xiàn)跨瀏覽器復制功能的方法,以及在實現(xiàn)過程中遇到的問題,感興趣的小伙伴們可以參考一下2015-11-11