JS循环遍历ul中li的点击事件给选中li添加css样式(示例代码)
推荐阅读:
功能:对于一个ul中固定的li个数,当点击其中一个li时,改变选中li的颜色;同时改变对应的另一个ul中li的颜色
页面初始化的界面:
HTML:
<div > <label>其他推荐:</label> <ul> <li class="other_recommend" id="recommend1">10:21</li> <li class="other_recommend" id="recommend2">10:22</li> <li class="other_recommend" id="recommend3">10:25</li> <li class="other_recommend" id="recommend4">10:28</li> <li class="other_recommend" id="recommend5">10:30</li> </ul> </div> <br /> <div> <label>剩余红包数:</label> <ul> <li id="num1" class="number">200</li> <li id="num2" class="number">150</li> <li id="num3" class="number">100</li> <li id="num4" class="number">50</li> <li id="num5" class="number">20</li> </ul> </div>
在js中定义“其他事件”里面的li点击事件,改变选中li的样式(代码用jquery写的):
// 设置选中的推荐的时间和红包数的背景色和字体颜色 // 推荐的时间 var $recommend1 = $("#recommend1"), $recommend2 = $("#recommend2"), $recommend3 = $("#recommend3"), $recommend4 = $("#recommend4"), $recommend5 = $("#recommend5"), $num1 = $("#num1"), $num2 = $("#num2"), $num3 = $("#num3"), $num4 = $("#num4"), $num5 = $("#num5"); var times=new Array($recommend1,$recommend2,$recommend3,$recommend4,$recommend5); var nums = new Array($num1,$num2,$num3,$num4,$num5); // 添加Input选中背景色 $recommend1.click(function(){ setSelectedTime($recommend1,$num1); }); $recommend2.click(function(){ setSelectedTime($recommend2,$num2); }); $recommend3.click(function(){ setSelectedTime($recommend3,$num3); }); $recommend4.click(function(){ setSelectedTime($recommend4,$num4); }); $recommend5.click(function(){ setSelectedTime($recommend5,$num5); }); function setSelectedTime(selectedTime,num){ if (selectedTime.hasClass('active1')){ //不处理 }else{ //遍历数组把,其他的remove for (var i = 0; i < times.length; i++) { var time = times[i]; if (time.hasClass('active1')) { time.removeClass('active1'); } } for (var i = 0; i < nums.length; i++) { var n = nums[i]; if (n.hasClass('active2')) { n.removeClass('active2'); } } //原来是没有被选中的状态 selectedTime.addClass('active1'); num.addClass('active2'); } }
思路如下:
1、 定义times和nums数组,分别存放两个ul的li;
2、给第一个ul中的每一个li定义点击事件:
$recommend1.click(function(){ setSelectedTime($recommend1,$num1); }); $recommend2.click(function(){ setSelectedTime($recommend2,$num2); }); $recommend3.click(function(){ setSelectedTime($recommend3,$num3); }); $recommend4.click(function(){ setSelectedTime($recommend4,$num4); }); $recommend5.click(function(){ setSelectedTime($recommend5,$num5); });
3、定义点击触发事件所实现的功能函数:给选中的li添加样式类
selectedTime表示第一个ul中的某个li的id,num表示第二个ul中对应的li的id
function setSelectedTime(selectedTime,num){ if (selectedTime.hasClass('active1')){ }else{ //遍历数组把,其他的remove for (var i = 0; i < times.length; i++) { var time = times[i]; if (time.hasClass('active1')) { time.removeClass('active1'); } } for (var i = 0; i < nums.length; i++) { var n = nums[i]; if (n.hasClass('active2')) { n.removeClass('active2'); } } //原来是没有被选中的状态 selectedTime.addClass('active1'); num.addClass('active2'); } }
setSelectedTime()函数用来添加选中Li的样式,其中在函数里面用到for循环来实现遍历上次选中的Li,如果上次选中的li和当前选中的li不一样,就要把上次选中的Li添加的类去掉,然后给当前选中的Li添加类样式。
css部分样式如下:
.active1{ background: #1FD823; border: #1FD823; } .active2{ color: #1FD823; }
点击实现效果如下:
到此这篇关于js循环遍历ul中li的点击事件,给给选中li添加css的文章就介绍到这了,更多相关js循环遍历li添加css内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
JavaScript 面向对象程序设计详解【类的创建、实例对象、构造函数、原型等】
这篇文章主要介绍了JavaScript 面向对象程序设计,结合具体实例形式详细分析了JavaScript面向对象程序设计中类的创建、实例对象、构造函数、原型等相关概念、原理、用法及操作注意事项,需要的朋友可以参考下2020-05-05input框中自动展示当前日期yyyy/mm/dd的实现方法
下面小编就为大家带来一篇input框中自动展示当前日期yyyy/mm/dd的实现方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧2017-07-07
最新评论