JSP+java script开发一个有增加行删除行的表格


页面部分:

<%@ page contentType="text/html;charset=GBK"%>

<html style="height:100%">

<head>

    <title>页面标题</title>

    <jsp:include  flush="true" page="include.jsp?file=jquery,ext"></jsp:include>

</head>

<body>

    <table width="100%" border="1" cellpadding="0" cellspacing="1" style="font-size:14px;"  id="tb">

        <tr bgcolor="#EFFOF1"> 

             <td colspan="5">人员信息</td>

            <td>

             <input type="button"   value="增加行"  id="add" onClick="addrow(tb)">

             <input type="button"    value="删除行"   id="del" onClick="delrow()";>

             </td>

        </tr>

        <tr>

             <td width="15%">姓名</td>

            <td width="15%">年龄</td>

            <td width="15%">联系电话</td>

            <td width="15%">职位</td>

            <td width="15%">职龄</td>

            <td width="25%">地址</td>

        </tr>

    </table>

</body>

script部分:

<script>

    var cycleCount=0+1;

    var num=0;

    function addrow(tablename){

       num=num+1;

       var len=tablename.rows.length;

       var vtr=tablename.insertRow(len);

 

       vtr.insertCell(0).innerHTML='<td><input type="checkbox" name="ckbox"><input type="text" name="name" size="15"></td>';

       vtr.insertCell(1).innerHTML='<td><input type="text" name="age" ></td>';

       vtr.insertCell(2).innerHTML='<td><input type="text" name="address"></td>';

       vtr.insertCell(3).innerHTML='<td><input type="text" name="phone"></td>';

       vtr.insertCell(4).innerHTML='<td><input type="text" name="stat"></td>'; 

       vtr.insertCell(5).innerHTML='<td><input type="text" name="workyear"></td>';  

        cycleCount=cycleCount+1;  

        document.getElementById("cycleCount").value=cycleCount;

}


//判断是否有选中数据

function checkSelected(chs){

     for(var i=0;i<chs.length;i++){

         var ele=chs[i];

         if(ele.type=="checkbox"&&ele.checked==true)

             return true;

     }

     return false;

}


function delrow(){

     window.event.returnValue=false;

     var chs =document.getElementsByName('ckbox');

     if(!checkSelected(chs)){

          alert("请你选择要删除的数据!");

          return false;

     }else{

          if(confirm("你确定要删除选中的数据?")){

                for(var i=chs.length-1;i>=0;i--){

                     var ele=chs[i];

                     if(ele.type=="checkbox"&&ele.checked==true)

                          tb.deleteRow(i+2);   

                 }

           }

                 return false;

     }

}


</script>








  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要实现这个效果,你可以使用 JSP 和 Servlet 结合的方式来实现。 首先,你需要在 JSP 页面中创建一个表格,并在表格的每一中添加一个按钮。按钮的文本可以是“点击”或“未点击”,根据按钮是否被点击来动态修改文本。此外,每个按钮都需要有一个唯一的 ID,以便在后续处理中进标识。 以下是示例代码: ```jsp <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>点击表格中每的按钮</title> </head> <body> <table> <tr> <th>ID</th> <th>姓名</th> <th>性别</th> <th>操作</th> </tr> <% for (int i = 0; i < userList.size(); i++) { %> <tr> <td><%= userList.get(i).getId() %></td> <td><%= userList.get(i).getName() %></td> <td><%= userList.get(i).getGender() %></td> <td><button id="btn<%= userList.get(i).getId() %>" onclick="changeText(this)">点击</button></td> </tr> <% } %> </table> <script> function changeText(btn) { if (btn.innerHTML === "点击") { btn.innerHTML = "未点击"; } else { btn.innerHTML = "点击"; } } </script> </body> </html> ``` 注意,上面的代码使用了 JSP 的脚本语法,`userList` 是一个包含用户信息的 List 对象。在表格的每一中,我们为按钮设置了一个唯一的 ID,格式为 `btn${user.id}`,其中 `${user.id}` 表示当前用户的 ID。当用户点击按钮时,`changeText()` 函数会被调用,根据按钮当前的文本来动态修改文本。 接下来,你需要在 Servlet 中处理用户的点击事件。当用户点击按钮时,你可以通过 AJAX 技术将按钮的 ID 发送到 Servlet,然后在 Servlet 中将对应的按钮文本修改为“已点击”,并返回修改后的数据给前端页面。以下是示例代码: ```java @WebServlet("/changeButton") public class ChangeButtonServlet extends HttpServlet { private static final long serialVersionUID = 1L; protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { String id = request.getParameter("id"); // 根据 ID 修改按钮文本 // ... // 返回修改后的数据给前端页面 response.setContentType("text/plain;charset=UTF-8"); PrintWriter out = response.getWriter(); out.write("已点击"); out.close(); } } ``` 在上面的示例代码中,我们为 Servlet 创建了一个名为 `changeButton` 的 URL 映射,当用户点击按钮时,前端页面会通过 AJAX 请求将按钮的 ID 发送到该 URL。在 Servlet 中,我们通过 `request.getParameter("id")` 方法获取按钮的 ID,并根据该 ID 修改按钮文本。最后,我们将修改后的数据返回给前端页面。注意,在返回数据之前,我们需要设置响应类型为 `text/plain;charset=UTF-8`。 最后,你需要在前端页面中使用 JavaScript 和 AJAX 技术来处理用户的点击事件,并将修改后的数据更新到页面上。以下是示例代码: ```jsp <script> function changeText(btn) { var id = btn.id.substring(3); // 获取按钮的 ID var xhr = new XMLHttpRequest(); xhr.open("POST", "changeButton", true); xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); xhr.onreadystatechange = function() { if (xhr.readyState == 4 && xhr.status == 200) { btn.innerHTML = xhr.responseText; } }; xhr.send("id=" + id); } </script> ``` 在上面的示例代码中,我们定义了一个 `changeText()` 函数,该函数会在用户点击按钮时被调用。首先,我们获取按钮的 ID,然后创建一个 AJAX 请求,将按钮的 ID 发送到 Servlet,等待响应数据返回。当数据返回时,我们将修改后的数据更新到按钮的文本中。注意,在发送 AJAX 请求时,我们需要设置请求类型为 `POST`,并将数据以 `application/x-www-form-urlencoded` 的形式发送过去。在响应数据返回后,我们通过 `xhr.responseText` 获取响应文本,并将其更新到按钮的文本中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值