JavaScript利用键盘方向键(上下键)控制表格行选中
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<style type="text/css">
.buddyListOdd{
background-color:#f0f0f0;
}
.buddyListEven{
background-color:#ffffff;
}
.buddyListHighLight{
background-color:#DCE2E8;
}
</style>
<SCRIPT LANGUAGE="JavaScript">
var currentLine=-1, offsetTr = 0;
var $=function(id){
return document.getElementById(id);
}
function keyDownEvent(e){
var e = window.event||e;
if(e.keyCode==38){
offsetTr = 0;
currentLine--;
changeItem();
}else if(e.keyCode==40){
offsetTr = 150;
currentLine++;
changeItem();
}else if(e.keyCode==13&¤tLine>-1){
addUser();
}
return false;
}
function changeItem(){
if(!$('buddyListTable')) return false;
var it = $('buddyListTable');
if(document.all){
it = $('buddyListTable').children[0];
}
changeBackground();
if(currentLine<0) currentLine = it.rows.length-1;
if(currentLine >= it.rows.length) currentLine = 0;
it.rows[currentLine].className = "buddyListHighLight";
if($('allBuddy')){
$('allBuddy').scrollTop = it.rows[currentLine].offsetTop-offsetTr;
}
}
function changeBackground(){
var it = $('buddyListTable');
if(document.all){
it = $('buddyListTable').children[0];
}
for(var i=0; i<it.rows.length; i++){
if(i%2==0){
it.rows[i].className = "buddyListOdd";
}else{
it.rows[i].className = "buddyListEven";
}
}
}
function addUser(){
var it = $('buddyListTable');
if(document.all){
it = $('buddyListTable').children[0];
}
var trBody = it.rows[currentLine].innerHTML;
$('result').innerHTML = $('result').innerHTML+trBody;
}
</SCRIPT>
</head>
<body>
<table cellspacing="0" cellpadding="0" border="0" width="100%" id="buddyListTable"><tbody>
<tr class="buddyListOdd" onkeyup="return keyDownEvent(event);">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">AAAAAA</td>
<td align="left">+861311111111</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">BBBBBB</td>
<td align="left">+861322222222</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">CCCCCC</td>
<td align="left">+861333333333</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">DDDDDD</td>
<td align="left">+861333333333</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">DDDDDD</td>
<td align="left">+861344444444</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">EEEEEE</td>
<td align="left">+861355555555</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">FFFFFF</td>
<td align="left">+861366666666</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">GGGGGG</td>
<td align="left">+861366666666</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">HHHHHH</td>
<td align="left">+861377777777</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">IIIIII</td>
<td align="left">+861388888888</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">JJJJJJ</td>
<td align="left">+861399999999</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">KKKKKK</td>
<td align="left">+861321111111</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">LLLLLL</td>
<td align="left">+861322222222</td>
</tr>
<tr class="buddyListOdd">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">MMMMMM</td>
<td align="left">+861323333333</td>
</tr>
<tr class="buddyListEven">
<td width="26px"><input type="checkbox"></td>
<td align="left" valign="middle">NNNNNN</td>
<td align="left">+861324444444</td>
</tr>
</tbody>
</table>
<div>
首先把鼠标焦点放入下面的输入框,然后按键盘的上下键,可以看到表格中的行被高亮选中<br />
<input type="text" onkeyup="return keyDownEvent(event);"/><br />
按回车后,相对应的表格项会出现在下面,当然这只是一个简单的Demo,复杂的操作开发者可以自己添加<br />
<table id="result"></table>
</div>
</body>
</html>
JavaScript利用键盘方向键(上下键)控制表格行选中的更多相关文章
- AppBoxPro - 细粒度通用权限管理框架(可控制表格行内按钮)源码提供下载
特别声明: 提供的源代码已经包含了 AppBoxPro 的全部源代码,用 VS2012 打开项目后,直接 Ctrl+F5 可以运行起来(默认使用VS自带的LocalDB数据库). FineUIPro是 ...
- jQuery学习笔记(6)--复选框控制表格行高亮
<html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> &l ...
- jQuery控制表格行移动,序号不变
@model Gd.NetSign.Controllers.DTO.SysPamaterDTO @{ ViewBag.Title = "SysPamatList"; //Layou ...
- 在Bootstrap开发框架中使用dataTable直接录入表格行数据
在Winform开发的时候,我们很多时候可以利用表格控件来直接录入数据,不过在Web上较少看到,其实也可以利用dataTable对象处理直接录入表格行数据,这个可以提高数据的录入方便,特别是在一些简单 ...
- Javascript 检测键盘按键
Javascript中 有3个事件句柄在对应键盘的输入状态:keydown.keypress和keyup. 分别对应的意思是:按键被按下(按下按键但还没有抬起).点击按键(按下并抬起按键).按键抬起( ...
- JavaScript获取键盘事件
JavaScript中: onkeydown 事件会在用户按下一个键盘按键时发生. onkeypress 事件会在键盘按键被按下并释放一个键时发生. onkeyup 事件会在键盘按键被松开时发生. 支 ...
- javascript之键盘事件
键盘事件包含onkeydown.onkeypress和onkeyup这三个事件 事件初始化 function keyDown(){} document.onkeydown = keyDown; ...
- javascript的键盘事件大全
javascript的键盘事件大全 ------------------------------------------------------------------- 使用event对象的keyC ...
- C#基础知识之键盘对应的键值
1.一般的按键禁用 一般的按键禁用只要找出相应的keycode禁用即可.例如:window.event.keyCode==13 //Enter键 其他可以对照一下的keyCode进行选择. 字母和数字 ...
随机推荐
- 代码管理工具Git的安装及使用
一:Git是什么? Git是目前世界上最先进的分布式版本控制系统. 二:SVN与Git的最主要的区别? SVN是集中式版本控制系统,版本库是集中放在中央服务器的,而干活的时候,用的都是自己的电脑,所以 ...
- python中的日志操作和发送邮件
1.python中的日志操作 安装log模块:pip install nnlog 参数:my_log = nnlog.Logger('server_log.log',level='debug',bac ...
- mysql 原理 ~ DDL之mdl锁
一 简介: MDL锁 二 具体 1 MDL锁 1 增删查改 申请MDL读锁 2 ddl语句 1. 拿MDL写锁 2. 降级成MDL读锁 3. 真正做DDL ...
- Spark架构与作业执行流程简介
https://www.cnblogs.com/shenh062326/p/3658543.html
- 20165231 2017-2018-2 《Java程序设计》第7周学习总结
教材学习内容总结 第十一章 MySQL数据库管理系统,简称MySQL,是世界上最流行的开源数据库管理系统,其社区版(MySQL Community Edition)是最流行的免费下载的开源数据库管理系 ...
- 【Linux-Redhat】新手需要知道的Linux命令
好像接触运维有一年的时间了吧,查的资料什么的,也算是挺多的了.再加上最近看的<Linux就该这么学>,也算是把自己最近学的东西系统化了一下.今天就来说说,常用的Linux命令有什么,如果你 ...
- Linux下查询文件的md5,sha1值
验证下载下来的文件包是不是一致 ··· 验证md5值 #md5sum filename 验证shal值 #sha1sum filename ···
- RabbitMQ 选型和对比
背景 这个纯粹是记下知识点,知道自己在这个时候了解过这个技术.技术点网上很多,就不多说了.只是想起多年前做过的一次项目,是多个项目整合,各种数据库,java和c#项目,互相调来调去,甚至直接链接对方数 ...
- bigfile tablespace
背景 这次终于有个linux实际迁移oracle的机会了,之前都是学习实验.想起最早时,都是windows搞oracle,又让我想起多年期一个项目,数据量太大及计算逻辑太复杂,我用存储过程 ...
- jquery简单使用入门
<!DOCTYPE html> <html> <head> <title>jquery</title> <meta charset=& ...