JS表格隔行变色效果的实现方法及注意事项是什么
Admin 2022-11-15 群英技术资讯 541 次浏览
用到的鼠标事件:(1)鼠标经过 onmouseover;(2)鼠标离开 onmouseout
核心思路:鼠标经过 tr 行的时候,当前行会改变背景颜色,鼠标离开的时候去掉背景颜色。
注意:第一行(thead 里面的行)不需要变换颜色,改变的是 tbody 里面的行。
1、获取元素,获取的是 tbody里面的行。
2、循环注册绑定事件,将 tbody 里面全部的行都得到,然后全部都注册鼠标经过和离开事件。
3、所有行绑定鼠标经过事件,鼠标经过当前元素(this)改变颜色;
4、所有行绑定鼠标离开事件,鼠标离开当前元素(this)没有颜色;
代码如下:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>表格隔行变色</title> <style type="text/css"> *{ margin:0;padding: 0; } table{ width:500px; position:relative; margin:100px auto; border-collapse:collapse; /*合并表格单一边框*/ border:1px solid #d7d7d7; } thead tr{ background-color:#ccc; height:30px; } table tr{ text-align: center; height:30px; } .bg{ background: #eee; } </style> </head> <body> <table border=1> <thead> <tr> <td width="40">序号</td> <td width="100">前端单词</td> <td width="80">基本释义</td> <td width="50">长度</td> <td width="">补充</td> </tr> </thead> <tbody> <tr> <td>1</td> <td>select</td> <td>选择</td> <td>6</td> <td>-</td> </tr> <tr> <td>2</td> <td>target</td> <td>目标</td> <td>6</td> <td>-</td> </tr> <tr> <td>3</td> <td>input </td> <td>输出</td> <td>5</td> <td>-</td> </tr> <tr> <td>4</td> <td>button</td> <td>按钮</td> <td>8</td> <td>-</td> </tr> <tr> <td>5</td> <td>checkbox</td> <td>复选框</td> <td>8</td> <td>-</td> </tr> </tbody> </table> <script> //1、获取tbody里面的所有的行 var trs = document.querySelector('tbody').querySelectorAll('tr'); //2、利用循环注册事件 for(var i = 0;i<trs.length;i++){ var bgc = function(e){this.className = 'bg';} trs[i].addEventListener('mouseover',bgc) trs[i].onmouseout = function(){ this.className = ''; } } </script> </body> </html>
显示效果:
当鼠标滑过时:
当鼠标离开时:
当然这个效果使用 CSS的 :hover 可以非常简单的实现(tbody tr:hover{background: #eee;}),但是在这个例子中主要想体现的是使用JS事件和排他思想实现的效果。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要给大家分享用JS实现动态表格效果,也就是点击增加或者删除就可以自动增加或删除表格的行,小编觉得还是比较实用的,感兴趣的朋友可以参考一下,希望大家阅读完这篇文章能有所收获,下面我们一起来学习一下吧。
这篇文章给大家分享的是用JS怎样实现魔方动态转换的效果,实现效果及代码如下,是一种酷炫的展示效果,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
instanceof运算符用于检测构造函数的prototype属性是否出现在某个实例对象的原型链上,本文重点给大家介绍JavaScript手动实现instanceof的问题,感兴趣的朋友跟随小编一起看看吧
这篇文章给大家分享的JS实现动态添加圆圈序号效果。小编觉得挺实用的,而且这种效果的效果也比较美观,因此分享给大家做个参考,文中示例代码介绍的非常详细,感兴趣的朋友接下来一起跟随小编看看吧。
jquery初始化方法通常是下面这四种,使用非常的普遍,js初始化是在界面加载完成后执行的一些函数,在使用jquery初始化之前需要在head标签内引入jquery包,例如: scripttype=text/javascriptsrc=./js/jquery.min.js/script Jquery初始化方法一: scripttype=
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008