原生js实现音乐列表(隔行换色、全选)
一、实现原理:
1、使用 % 运算符实现各行换色,规律:当%前面的值和后面的值相同时 结果为0;
2、使用开关思想,实现在同一个元素上反复点击时的条件判断,并且把开关以属性方式绑定在每个元素上;
3、使用大总管变量,记录鼠标移入时的下标,用于设置鼠标离开时的颜色
4、使用变量记录每选中一行就自增1 取消选中就自减1,当变量数值与行的长度相等时 说明全选了;
二、代码:

<!DOCTYPE html>
<html>
<head>
<title></title>
<style type="text/css">
*{margin: 0;padding: 0}
ul,li{ list-style: none; }
.wrap{width:300px; margin: 50px auto;padding: 10px;border: 1px solid #eee;}
.wrap ul{display: block; overflow: hidden;clear: both;}
.wrap ul li{display:block;width:100%; float: left; height: 40px;line-height: 40px; overflow: hidden; clear: both;}
.wrap ul li.on{ background: #222 !important;color: #fff; }
#all{border-top:1px solid #eee;}
</style>
</head>
<body>
<div class="wrap">
<ul id="box">
<li><input type="checkbox">认真的雪</li>
<li><input type="checkbox">再见</li>
<li><input type="checkbox">大约在冬季</li>
<li><input type="checkbox">蜗牛</li>
<li><input type="checkbox">光辉岁月</li>
</ul>
<div id="all">
<input type="checkbox">全选
</div>
</div>
<script type="text/javascript">
window.onload = function(){
var box = document.getElementById('box')
var lis = box.getElementsByTagName('li');
var cklist = box.getElementsByTagName('input');
var allbtn = document.getElementById('all').getElementsByTagName('input')[0];
allbtn.onoff = true;//设置开关 用于多次点击时的状态判断
var colorArr = ['orange','pink'];
var num; //大总管变量,记录鼠标移入时的下标,用于设置鼠标离开时的颜色
var allnum = 0; // 每选中一行就自增1 取消选中就自减1
for (var i = 0; i < lis.length; i++) {
// 给每一行加下标
lis[i].index = i;
// 给每一行加开关
lis[i].onoff = true;
// js实现隔行换色
lis[i].style.background = colorArr[i%colorArr.length];
// 鼠标移入行
lis[i].onmouseover = function(){
num = this.index;
this.style.background = '#ccc';
}
// 鼠标移出行
lis[i].onmouseout = function(){
this.style.background = colorArr[num%colorArr.length];
}
// 鼠标点击
lis[i].onclick = function(){
//判断该li上的开关,如果为true则添加选中状态,否则就去除选中状态
if(this.onoff){
//设置当前为选中状态,当前行上的checkbox为选中状态,变量自增1
this.className = 'on';
cklist[this.index].checked = 'checked';
allnum++;
}else{
//设置当前为默认状态,当前行上的checkbox为非选中状态,变量自减1
this.className = '';
cklist[this.index].checked = '';
allnum--;
}
//更改当前行上的开关属性
this.onoff = !this.onoff;
// 根据allnum变量判断 全选按钮是否应该选中
if( allnum == cklist.length ) {
allbtn.checked = 'checked'
}else{
allbtn.checked = ''
}
}
};
allbtn.onclick = function(){
if(allbtn.onoff){
for (var i = 0; i < lis.length; i++) {
lis[i].className = 'on';
cklist[i].checked = 'checked';
lis[i].onoff = false;
}
}else{
for (var i = 0; i < lis.length; i++) {
lis[i].className = '';
cklist[i].checked = '';
lis[i].onoff = true;
}
}
allbtn.onoff = !allbtn.onoff;
}
}
</script>
</body>
</html>
原生js实现音乐列表(隔行换色、全选)的更多相关文章
- jQuery-----隔行换色/全选全不选/
隔行换色: 全选全不选: 分析: 1.页面加载 $(function(){}) 2.获取所有奇数行数 ...
- 使用JS创建表格以及隔行换色(包括隔N行换色)
<html> <head> <title></title> <style> table{ width:800px; border-colla ...
- DTcms列表隔行换色;loop自带行号
<%loop cdr2 bcategoryList%> <%if(cdr2__loop__id==1)%> <a class="no-bg" href ...
- JS给TR隔行换色,鼠标经过有动感
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN" "http://www.w3.org/TR/xhtml11/DT ...
- 利用JS动态生成隔行换色HTML表格
用JS生成动态生成表格,行.列由用户输入,并使表格隔行换色 方法一. 代码: <!DOCTYPE html> 2 <html> 3 <head> 4 <tit ...
- js课程 4-11 表格如何实现隔行换色
js课程 4-11 表格如何实现隔行换色 一.总结 一句话总结:表格奇数行和偶数行判断,赋予不同的样式. 1.表格如何隔行换色? 表格奇数行和偶数行判断,赋予不同的样式. 21 <script& ...
- JS实现自定义工具类,隔行换色、复选框全选、隔行高亮等
很多功能都可以放在js的工具类中,在使用的时候直接调用 本次实现的功能包括: /** 0.当点击表的整行的任意位置时,第一列的复选框或者单选框均选中 1.隔行换色 2.复选框的全选效果 3.实现表格 ...
- JS应用实例4:表格隔行换色
HTML代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <t ...
- js实现表单的隔行换色、鼠标高亮出来等相关内容以及相关事件的作用
主要是使用的onload().onmouseover和onmouseout的相关应用,满足此次的相关操作. 具体的相关的两个代码如下: <!DOCTYPE html> <html&g ...
随机推荐
- lrj 9.2.3
<<); // 记忆化搜索 min[] = ; int dp(int i) { ) return maxv[i]; maxv[i] = -INF; ; j <= n; j++) if ...
- 在vuex的mutations中使用vue的小技巧
问题: 在vuex组件中的mutations属性中的定义的函数,有时会要用到vue这个对象.正常在其他的地方使用是通过this这个变量来获取,但是在mutations定义的函数中this指定的是Vue ...
- 怎么让FOXMAIL关了以后在右下角自动收取邮件
1.缩小到任务栏:打开foxmail,在工具-系统设置-常规,选项中有一项最小化时在任务栏显示,勾选上即可.2.要自动收取邮件,选中邮件账户,右键打开菜单,属性-接收邮件,右边勾选上“每隔*分钟自动收 ...
- P1095 水仙花数
题目描述 春天是鲜花的季节,水仙花就是其中最迷人的代表,数学上有个水仙花数,他是这样定义的:"水仙花数"是指一个三位数,它的各位数字的立方和等于其本身,比如:153=1^3+5^3 ...
- 「THUPC 2019」不等式 / inequality
https://loj.ac/problem/6620 高中数学好题.. |kx+b|的函数图像很直观,直接考虑函数图像: 一定只有一段极小值点! 这个点就是最小值了 特点:斜率为0! 而且发现,如果 ...
- Canvas动画:地球绕着太阳转
<!DOCTYPE html> <html lang="zh"> <head> <meta charset="UTF-8&quo ...
- remote api
iperf -B 99.99.3.1 -c 192.168.42.242 -p 10002 -f m -i 1 -P 1 -w 1M -u -b 1M -t 20 iperf -B 192.168.4 ...
- Team Foundation Server 2015使用教程【2】:默认团队成员添加
官方文档:https://www.visualstudio.com/en-us/docs/setup-admin/add-users
- 第二阶段:2.商业需求文档MRD:5.MRD-Roadmap及规划
产品路线图可以用泳道图来实现.将之前做过的泳道图的角色换为阶段即可. 可以以月为单位.左边就是一些产品的功能. 基础功能,有的功能会跨月甚至夸功能模块.比如图中的会员等级. 通过线段来联系各个功能与先 ...
- 第二阶段:2.商业需求分析及BRD:7.商业需求文档3
BRD模版 阐述需求来源以及调研分析情况 百度指数工具.定量的数据.发展趋势,是否与公司的战略冲突.环境政策:比如做内容的运营. 决策层看重的! 第二大块. 通过什么方式解决这个需求. 规划能力.类似 ...