页面中如下格式的人员信息表格:
表格每行的HTML结构为:
<tr> <td><input type="checkbox"></td> <td>2</td> <td>李斯</td> <td>43</td> <td>陕西</td></tr>
假定表格的元素id为person-list,奇数行的class名为odd。 请实现如下功能:
1、选中单选框,点击删除时对应行消失;
2、点击排序时,按照升序对表格中的每一行进行排序;
3、点击筛选,籍贯处会变成一个下拉框,选项值为当前表格中锁包含的省份名称,选中某个省份,展示对应省份的人员信息
实现代码:
<!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8"> <title>人员信息表格</title> <style type="text/css"> body { font-family: "arial", sans-serif; } #person-list { width: 80%; margin-left: 10%; margin-right: 10%; } #person-list thead { font-weight: bold; } #person-list button { background-color: transparent; border: 0; font-weight: bold; font-size: small; padding-left: 0; color: #6ba9ee; } #person-list thead tr td { border-bottom: 1px #ccc solid; } #person-list tbody tr td:nth-child(2) { font-weight: bold; } #person-list tbody tr td { border-top: 1px #ccc solid; padding-top: 5px; padding-bottom: 5px; } #person-list tbody tr:nth-child(2n+1) { background-color: #eee; } </style> <script type="text/javascript"> window.onload=function(){ if (!document.getElementsByClassName) {//由于较低版本的IE不识别这个。 document.getElementsByClassName=function(cls){ var ret=[]; var eles=document.getElementsByTagName('*'); for(var i=0,len=eles.length;i<len;i++){//indexOf()返回的是字母在字符串中的下标,>=0代表存在 if (eles[i].className===cls /*===是严格等于*/ ||eles[i].className.indexOf(cls+'')>=0//当比较'aaa'和'aaa '时 ||eles[i].className.indexOf(''+cls+'')>=0///比较'aaa'和'bbb aaa ccc'时 ||eles[i].className.indexOf(''+cls)>=0///比较'aaa'和' aaa'时 ) { ret.push(eles[i]); } } return ret; } } var checks = document.getElementsByTagName('input'); var tbody = document.getElementsByTagName("tbody")[0]; var trs = tbody.getElementsByTagName('tr'); var remove = document.getElementById("remove"); var sort = document.getElementById("sort"); var select = document.getElementById("select"); remove.onclick = function(){ //删除选中行 for(var i = checks.length-1; i >= 0;i--){ //因为removeChild的时候,长度会变化,所以不能以小于length作为判断条件,应该从后往前扫描 if(checks[i].checked){ tbody.removeChild(checks[i].parentNode.parentNode); } } //修改序号 for(var i = 0;i < trs.length; i++){ var td=trs[i].getElementsByTagName("td")[1]; td.innerHTML=i+1; } }; sort.onclick=function(){ //循环遍历,后面比它小的就插入到它前面去 for(var i=0;i < trs.length; i++){ var td=trs[i].getElementsByTagName("td")[3]; for(var j=i;j < trs.length;j++){ var tdd=trs[j].getElementsByTagName("td")[3]; if((td.innerHTML - tdd.innerHTML)>0){ td.parentNode.parentNode.insertBefore(tdd.parentNode,td.parentNode); } } } //修改序号 for(var i=0;i < trs.length;i++){ var td=trs[i].getElementsByTagName("td")[1]; td.innerHTML=i+1; } }; select.onclick=function(){ //如果已经筛选过,页面中有下拉框了就不要再执行此函数了。 if(document.getElementsByTagName('select').length>0) return false; var provinces = []; //把所有的省份取出来,存放到数组里 for(var i=0;i < trs.length;i++){ var td=trs[i].getElementsByTagName("td")[4]; var prov=td.innerHTML; provinces.push(prov); } //去重 for(var j=0;j< provinces.length;j++){ for(var k=provinces.length;k>j;k--){ //同理,因为长度会发生变化,所以从后往前算 if(provinces[j] === provinces[k]){ provinces.splice(k,1); } } } //创建selectElem下拉框元素,option为省份 var selectElem = document.createElement("select"); for(var z = 0;z < provinces.length;z++){ var option=document.createElement("option"); option.innerHTML=provinces[z]; option.value=provinces[z]; selectElem.appendChild(option); } var childNodes=select.parentNode.childNodes; //去掉籍贯两个字 for(var x= 0; x< childNodes.length;x++){ if(childNodes[x].nodeType === 3){ childNodes[x].parentNode.removeChild(childNodes[x]); } } //在按钮之前插入select下拉框 select.parentNode.insertBefore(selectElem,select); //监控下拉框的option的点击事件,注意是下拉框的onchange,而不是option的onclick selectElem.onchange = function(){ for(var i =0 ;i< trs.length;i++){ trs[i].style.display="none" ; if(trs[i].getElementsByTagName("td")[4].innerHTML == selectElem.value){ trs[i].style.display = ""; } } }; }; } </script></head><body> <table id="person-list"> <thead> <tr> <td> <button id="remove">删除</button> </td> <td>序号</td> <td>姓名</td> <td>年龄 <button id="sort">排序</button> </td> <td>籍贯 <button id="select">筛选</button> </td> </tr> </thead> <tbody> <tr> <td> <input type="checkbox"/> </td> <td>1</td> <td>张三</td> <td>24</td> <td>北京</td> </tr> <tr> <td><input type="checkbox"/> </td> <td>2</td> <td>李斯</td> <td>43</td> <td>陕西</td> </tr> <tr> <td><input type="checkbox"/> </td> <td>3</td> <td>韩信</td> <td>49</td> <td>湖北</td> </tr> <tr> <td><input type="checkbox"/> </td> <td>4</td> <td>宋江</td> <td>43</td> <td>山东</td> </tr> <tr> <td><input type="checkbox"/> </td> <td>5</td> <td>李逵</td> <td>38</td> <td>青海</td> </tr> <tr> <td><input type="checkbox"/> </td> <td>6</td> <td>林冲</td> <td>42</td> <td>北京</td> </tr> </tbody> </table></body></html>
相关推荐:
以上是前端案例:使用js实现表格对应行删除、排序、筛选的详细内容。更多信息请关注PHP中文网其他相关文章!

Python和JavaScript在开发环境上的选择都很重要。1)Python的开发环境包括PyCharm、JupyterNotebook和Anaconda,适合数据科学和快速原型开发。2)JavaScript的开发环境包括Node.js、VSCode和Webpack,适用于前端和后端开发。根据项目需求选择合适的工具可以提高开发效率和项目成功率。

是的,JavaScript的引擎核心是用C语言编写的。1)C语言提供了高效性能和底层控制,适合JavaScript引擎的开发。2)以V8引擎为例,其核心用C 编写,结合了C的效率和面向对象特性。3)JavaScript引擎的工作原理包括解析、编译和执行,C语言在这些过程中发挥关键作用。

JavaScript是现代网站的核心,因为它增强了网页的交互性和动态性。1)它允许在不刷新页面的情况下改变内容,2)通过DOMAPI操作网页,3)支持复杂的交互效果如动画和拖放,4)优化性能和最佳实践提高用户体验。

C 和JavaScript通过WebAssembly实现互操作性。1)C 代码编译成WebAssembly模块,引入到JavaScript环境中,增强计算能力。2)在游戏开发中,C 处理物理引擎和图形渲染,JavaScript负责游戏逻辑和用户界面。

JavaScript在网站、移动应用、桌面应用和服务器端编程中均有广泛应用。1)在网站开发中,JavaScript与HTML、CSS一起操作DOM,实现动态效果,并支持如jQuery、React等框架。2)通过ReactNative和Ionic,JavaScript用于开发跨平台移动应用。3)Electron框架使JavaScript能构建桌面应用。4)Node.js让JavaScript在服务器端运行,支持高并发请求。

Python更适合数据科学和自动化,JavaScript更适合前端和全栈开发。1.Python在数据科学和机器学习中表现出色,使用NumPy、Pandas等库进行数据处理和建模。2.Python在自动化和脚本编写方面简洁高效。3.JavaScript在前端开发中不可或缺,用于构建动态网页和单页面应用。4.JavaScript通过Node.js在后端开发中发挥作用,支持全栈开发。

C和C 在JavaScript引擎中扮演了至关重要的角色,主要用于实现解释器和JIT编译器。 1)C 用于解析JavaScript源码并生成抽象语法树。 2)C 负责生成和执行字节码。 3)C 实现JIT编译器,在运行时优化和编译热点代码,显着提高JavaScript的执行效率。

JavaScript在现实世界中的应用包括前端和后端开发。1)通过构建TODO列表应用展示前端应用,涉及DOM操作和事件处理。2)通过Node.js和Express构建RESTfulAPI展示后端应用。


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

Video Face Swap
使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热门文章

热工具

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),

SublimeText3 Linux新版
SublimeText3 Linux最新版

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。