您的位置:首页 > Web前端 > JQuery

带你学习JQuery:表格处理

2011-09-07 21:14 288 查看
最简单的,普通隔行变色:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

<head>

<title></title>

<link href="css/style.css" rel="stylesheet" type="text/css" />

<!-- 引入jQuery -->

<script src="../scripts/jquery-1.3.1.js" type="text/javascript"></script>

<script type="text/javascript">

$(function(){

$("tr:odd").addClass("odd"); /* 奇数行添加样式*/

$("tr:even").addClass("even"); /* 偶数行添加样式*/

})

</script>

</head>

<body>

<table>

<thead>

<tr><th>姓名</th><th>性别</th><th>暂住地</th></tr>

</thead>

<tbody>

<tr><td>张山</td><td>男</td><td>浙江宁波</td></tr>

<tr><td>李四</td><td>女</td><td>浙江杭州</td></tr>

<tr><td>王五</td><td>男</td><td>湖南长沙</td></tr>

<tr><td>找六</td><td>男</td><td>浙江温州</td></tr>

<tr><td>Rain</td><td>男</td><td>浙江杭州</td></tr>

<tr><td>MAXMAN</td><td>女</td><td>浙江杭州</td></tr>

</tbody>

</table>

</body>

</html>

稍微复杂一点:表头不算,即排除表头,JQuery代码如下

<script type="text/javascript">

$(function(){

$("tbody>tr:odd").addClass("odd"); //先排除第一行,然后给奇数行添加样式

$("tbody>tr:even").addClass("even"); //先排除第一行,然后给偶数行添加样式

})

</script>

再复杂一些,让某一行高亮显示:

比如说让王五这行高亮显示:

<script type="text/javascript">

$(function(){

$("tbody>tr:odd").addClass("odd"); //先排除第一行,然后给奇数行添加样式

$("tbody>tr:even").addClass("even"); //先排除第一行,然后给偶数行添加样式

$("tr:contains('王五')").addClass("selected");

})

</script>

再进一步,在第一列添加一列单选按钮,单击这一行时,高亮显示,同时单选按钮被选中

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

<head>

<title></title>

<link href="css/style.css" rel="stylesheet" type="text/css" />

<!-- 引入jQuery -->

<script src="../scripts/jquery-1.3.1.js" type="text/javascript"></script>

<script type="text/javascript">

$(function(){

$("tbody>tr:odd").addClass("odd"); //先排除第一行,然后给奇数行添加样式

$("tbody>tr:even").addClass("even"); //先排除第一行,然后给偶数行添加样式

$('tbody>tr').click(function() {

$(this)

.addClass('selected')

.siblings().removeClass('selected')

.end()//重新返回到$(this)对象

.find(':radio').attr('checked',true);

});

// 如果单选框默认情况下是选择的,则高色.

// $('table :radio:checked').parent().parent().addClass('selected');

//简化:

$('table :radio:checked').parents("tr").addClass('selected');

//再简化:

//$('tbody>tr:has(:checked)').addClass('selected');

})

</script>

</head>

<body>

<table>

<thead>

<tr><th> </th><th>姓名</th><th>性别</th><th>暂住地</th></tr>

</thead>

<tbody>

<tr><td><input type="radio" name="choice" value=""/></td>

<td>张山</td><td>男</td><td>浙江宁波</td></tr>

<tr><td><input type="radio" name="choice" value="" /></td>

<td>李四</td><td>女</td><td>浙江杭州</td></tr>

<tr><td><input type="radio" name="choice" value="" checked='checked' /></td>

<td>王五</td><td>男</td><td>湖南长沙</td></tr>

<tr><td><input type="radio" name="choice" value="" /></td>

<td>找六</td><td>男</td><td>浙江温州</td></tr>

<tr><td><input type="radio" name="choice" value="" /></td>

<td>Rain</td><td>男</td><td>浙江杭州</td></tr>

<tr><td><input type="radio" name="choice" value="" /></td>

<td>MAXMAN</td><td>女</td><td>浙江杭州</td></tr>

</tbody>

</table>

</body>

</html>

再进一步,第一列变成复选框:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">

<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en" lang="en">

<head>

<title></title>

<link href="css/style.css" rel="stylesheet" type="text/css" />

<!-- 引入jQuery -->

<script src="../scripts/jquery-1.3.1.js" type="text/javascript"></script>

<script type="text/javascript">

$(function(){

$("tbody>tr:odd").addClass("odd"); //先排除第一行,然后给奇数行添加样式

$("tbody>tr:even").addClass("even"); //先排除第一行,然后给偶数行添加样式

$('tbody>tr').click(function() {

if ($(this).hasClass('selected')) {

$(this)

.removeClass('selected')

.find(':checkbox').attr('checked',false);

}else{

$(this)

.addClass('selected')

.find(':checkbox').attr('checked',true);

}

});

// 如果复选框默认情况下是选择的,则高色.

// $('table :checkbox:checked').parent().parent().addClass('selected');

//简化:

$('table :checkbox:checked').parents("tr").addClass('selected');

//$('tbody>tr:has(:checked)').addClass('selected');

})

</script>

</head>

<body>

<table>

<thead>

<tr><th> </th><th>姓名</th><th>性别</th><th>暂住地</th></tr>

</thead>

<tbody>

<tr><td><input type="checkbox" name="choice" value=""/></td>

<td>张山</td><td>男</td><td>浙江宁波</td></tr>

<tr><td><input type="checkbox" name="choice" value="" /></td>

<td>李四</td><td>女</td><td>浙江杭州</td></tr>

<tr><td><input type="checkbox" name="choice" value="" checked='checked' /></td>

<td>王五</td><td>男</td><td>湖南长沙</td></tr>

<tr><td><input type="checkbox" name="choice" value="" /></td>

<td>找六</td><td>男</td><td>浙江温州</td></tr>

<tr><td><input type="checkbox" name="choice" value="" /></td>

<td>Rain</td><td>男</td><td>浙江杭州</td></tr>

<tr><td><input type="checkbox" name="choice" value="" /></td>

<td>MAXMAN</td><td>女</td><td>浙江杭州</td></tr>

</tbody>

</table>

</body>

</html>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: