html如何使标签“循环”改变背景色?

假设是一个在线点名册,通过点击“点名”这个列表行能循环改变背景色来区分是否“到”,同时“点名”按钮的文字也做相应改变。至于列表可以是li或表格。(“点名”按钮有“已到”“... 假设是一个在线点名册,通过点击“点名”这个列表行能循环改变背景色来区分是否“到”,同时“点名”按钮的文字也做相应改变。至于列表可以是li或表格。(“点名”按钮有“已到”“迟到”“请假”等状态,对应相应的背景色)万分感谢。 展开
 我来答
ml4w5
2017-05-28 · TA获得超过1394个赞
知道小有建树答主
回答量:625
采纳率:25%
帮助的人:648万
展开全部

思路:

  1. 准备3条CSS样式,对应“已到”、“迟到”和“请假”状态(也可按实际情况拓展):

  2. “点名”元素添加 onclick 事件,点击后依次切换3种状态以及对应文案。

完整代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>点名</title>
<style>
body {font:normal 14px/1.8 normal tahoma;}
.ui-table {width:900px; margin:0 auto; border-collapse:collapse;}
.ui-table td {padding:5px; text-align:center; border:1px solid #369;}

.is-here {background:#86e285;}  /* 已到 */
.is-late {background:#f69191;}  /* 迟到 */
.is-leave {background:#f6e291;} /* 请假 */
</style>
</head>
<body>
<table class="ui-table">
<tr>
<td>1</td>
<td>张三</td>
<td>
<a href="javascript:;" onclick="rollcall(this)">点名</a>
</td>
<td>短信</td>
<td>电话</td>
</tr>
<tr>
<td>2</td>
<td>李四</td>
<td>
<a href="javascript:;" onclick="rollcall(this)">点名</a>
</td>
<td>短信</td>
<td>电话</td>
</tr>
<tr>
<td>3</td>
<td>王五</td>
<td>
<a href="javascript:;" onclick="rollcall(this)">点名</a>
</td>
<td>短信</td>
<td>电话</td>
</tr>
</table>
<script>
var statusArr = [
{
name: "已到",
state: "is-here"
}, {
name: "迟到",
state: "is-late"
}, {
name: "请假",
state: "is-leave"
}
];

function rollcall(elm) {
var parent = elm.parentNode.parentNode,  // tr
idx = 0;
if (parent.className) {
for (var i = 0; i < statusArr.length; i++) {
if (parent.className === statusArr[i].state) {
if (i === statusArr.length - 1) {  // 最后一项
idx = 0;
} else {
idx = i + 1;
}
break;
}
}
}
parent.className = statusArr[idx].state;
elm.innerHTML = statusArr[idx].name;
}
</script>
</body>
</html>
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式