zoukankan      html  css  js  c++  java
  • js实现表格的增删改查

    这份代码实现了对表格的增加,删除,更改,查询。

    点击一次添加按钮,表格会增加一行。

    点击重置按钮,输入框的内容会被清空。

    添加一行后,最后两格为更改和删除。点击更改,原有内容会各自显示在一个输入框内,此时更改二字变为保存,更改内容后,点击保存,内容又呈现不可更改状态,保存二字又变为修改;点击删除,删除本行。

    在搜索框里输入对应文本,点击搜索,表格内匹配的文本背景变为其他颜色。

    <!doctype html>
    <html>
    <head>
    <meta charset="utf-8">
    <title>表格的增删改查</title>
    <style>
    table {
    text-align: center;
    border-collapse: collapse;
    border: 1px solid gray;
    }
    #tr1 {
    background: #99d6ff;

    }
    a {
    text-decoration: none;
    color: black;
    }
    </style>
    <script>
    window.onload=function()
    {var res = document.getElementById('res')
    var oTab=document.getElementById('table1')
    var oName=document.getElementById('name')
    var oAge=document.getElementById('age')
    var oBtn=document.getElementById('btn')
    var oSearch=document.getElementById('search')
    var oSearchBtn=document.getElementById('searchBtn')
    var id=oTab.tBodies[0].rows.length//定义序号变量


    oBtn.onclick=function()
    {
    var oTr=document.createElement('tr')

    var oTd=document.createElement('td')
    oTd.innerHTML=id++
    oTr.appendChild(oTd)

    var oTd=document.createElement('td')
    oTd.innerHTML=oName.value
    oTr.appendChild(oTd)

    var oTd=document.createElement('td')
    oTd.innerHTML=oAge.value
    oTr.appendChild(oTd)




    var td3=document.createElement('td');
    oTr.appendChild(td3);
    td3.innerHTML= '更改';
    td3.style.cursor = 'pointer';
    td3.onclick = function(){
    var ce = this.parentNode.cells;

    if (/.*更改.*/.test(td3.innerHTML)){
    for( var i = 0; i < ce.length - 2; i++) {
    var txt = document.createElement('input');
    txt.type = 'text';

    var ci = ce[i];
    txt.value =ci.innerHTML;

    ci.innerHTML = ' ';
    ci.appendChild(txt);



    }
    td3.innerHTML= '保存';
    }

    else{
    for( var i = 0; i < ce.length - 2; i++){
    var ci = ce[i];
    ci.innerHTML = ci.children[0].value;
    }
    td3.innerHTML= '更改';
    }



    }//更改


    var oTd=document.createElement('td')
    oTd.innerHTML='<a href="#">删除</a>'
    oTr.appendChild(oTd)//添加表格行

    oTd.getElementsByTagName('a')[0].onclick=function()
    {
    oTab.tBodies[0].removeChild(this.parentNode.parentNode)

    }//删除表格行

    oTab.tBodies[0].appendChild(oTr)
    }

    oSearchBtn.onclick=function()
    {

    for( var i=0; i<oTab.tBodies[0].rows.length; i++)
    {
    var sTab=oTab.tBodies[0].rows[i].cells[1].innerHTML.toLowerCase()
    var sTxt=oSearch.value.toLowerCase()
    var attr=sTxt.split('')
    oTab.tBodies[0].rows[i].style.background=''
    for( var j=0; j<attr.length; j++)
    {
    if(sTab.search(attr[j])!=-1)
    {
    oTab.tBodies[0].rows[i].style.background='#99d6ff';
    }

    }
    }
    }//模糊搜索,多关键字搜索


    res.onclick= function () {
    document.getElementById('form').reset();
    //重置
    }
    }

    </script>
    </head>

    <body>
    <form id="form">
    name:<input type="text" id="name" placeholder="请输入姓名">
    age:<input type="text" id="age" placeholder="请输入年龄">
    </form>
    <br>
    <input type="reset" id='res'>
    <input id="btn" type="button" value="添加"><br><br>
    <input type="text" id="search" placeholder="请输入你的姓名">
    <input type="button" id="searchBtn" value="搜索"><br><br>

    <table id="table1" border="1" width="800px">
    <tr id="tr1">
    <td>ID</td>
    <td>name</td>
    <td>age</td>

    <td>change</td>
    <td>delete</td>
    </tr>
    </table>
    </body>
    </html>

     

  • 相关阅读:
    前端开发面试题总结之——HTML
    HashMap的那些事
    抽象同步队列AQS(中)—— AQS的重点方法解析
    抽象同步队列AQS(上)—— 宏观上理解AQS
    synchronized原理详解
    volatile原理详解
    JMM模型详解
    计算机运行时内存&处理器CPU初步认知
    mysql-索引详解
    mysql-事务隔离机制&mvcc原理
  • 原文地址:https://www.cnblogs.com/iriliguo/p/6270639.html
Copyright © 2011-2022 走看看