JSP&EL&JSTL(案例1)_查询所有用户信息_3_实现列表界面相关按钮的添加3_删除选中&添加联系人&全选按钮

删除选中

1. 给删除选中按钮添加一个href属性,并且指向本地方法,写为"javascript:void(0);"

2. 在方法中先获取这个按钮的onclick事件

3. 在onclick事件中添加函数,函数中获取id值为checked的复选框,返回一个数组cbs

4. 定义一个flag,默认值为false,遍历cbs,判断如果cbs[i].checked为真,那么说明有复选框被选中,那么令flag=true

5. 如果flag为真,那么获取表单的id值,执行其submit()事件

6. 表单的 action="${pageContext.request.contextPath}/delSelectedServlet"

7. 写一个DelSelectedServlet,在其中获取id属性值为 checked,返回值为一个String类型的数组,将这个数组传给UserService中的delSelectedUser(ids),ids为上面提到的String类型的数组

8. 在这个方法中多次执行上一次文章中提到的dao层的删除单个记录的方法,首先应该判断,ids!=null&&ids.length>0 为真,如果为真,才能执行上面的方法


代码实现

    <div style="float:right;margin:5px">
        <a class="btn btn-primary" href="javascript:void(0);" id="delSelected">删除选中</a>
    </div>
    <form id="delSelected_form" action="${pageContext.request.contextPath}/delSelectedServlet" method="post">
        <table border="1" class="table table-bordered table-hover">
        <tr class="success">
            <th><input type="checkbox" id="firstCheckBox"></th>
            <th>编号</th>
            <th>姓名</th>
            <th>性别</th>
            <th>年龄</th>
            <th>籍贯</th>
            <th>QQ</th>
            <th>邮箱</th>
            <th>操作</th>
        </tr>

        <c:forEach items="${pb.list}" var="user" varStatus="s">
            <tr>
                <td><input type="checkbox" name="checked" value="${user.id}"></td>
                <td>${s.count}</td>
                <td>${user.name}</td>
                <td>${user.gender}</td>
                <td>${user.age}</td>
                <td>${user.address}</td>
                <td>${user.qq}</td>
                <td>${user.email}</td>
                <td><a class="btn btn-default btn-sm" href="${pageContext.request.contextPath}/findUserServlet?id=${user.id}">修改</a>&nbsp;
                    <a class="btn btn-default btn-sm" href="javascript:deleteUser(${user.id});">删除</a></td>
            </tr>
        </c:forEach>
    </table>
    </form>

在js代码里面添加onclick事件

window.onload=function () {
            //给删除选中按钮添加单击事件
            document.getElementById("delSelected").onclick=function () {
                if (confirm("您确定要删除选中条目吗?")){
                    var flag=false;
                    //判断有选中条目
                    var cbs=document.getElementsByName("checked");
                    for (var i = 0; i <cbs.length ; i++) {
                        if(cbs[i].checked){
                            flag=true;
                            break;
                        }
                    }
                    if (flag){
                        //有条目被选中
                        //表单提交
                        document.getElementById("delSelected_form").submit();
                    }

                }

            }

           
    </script>

DelSelectedServlet

package zr.web.userlist.web.Servlet;

import zr.web.userlist.service.UserService;
import zr.web.userlist.service.impl.UserServiceImpl;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;

@WebServlet("/delSelectedServlet")
public class DelSelectedServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1. 获取所有的id值
        String[] ids = request.getParameterValues("checked");
        //2. 盗用service删除
        UserService service=new UserServiceImpl();
        service.delSelectedUser(ids);
        //3. 跳转查询所有Servlet
        response.sendRedirect(request.getContextPath()+"/findUserByPageServlet");
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}

service层

接口

    /**
     * 批量删除用户
     * @param ids
     */

    void delSelectedUser(String[] ids);

实现类

    @Override
    public void delSelectedUser(String[] ids) {
        if (ids!=null&&ids.length>0){
            //1. 遍历数组
            for (String id : ids) {
                //2. 调用dao删除
                dao.delete(Integer.parseInt(id));
            }
        }

    }

delete方法见上一次博客中写的delete方法

这里面应该注意要在选中复选框之后,点击删除选中之后,需要弹出来一个确认提示框,“您确定你要删除选中的条目吗?”,只有用户点击了确定才能继续删除选中,如果点击了取消,那么不会执行任何步骤


添加联系人

1. 写一个add.jsp页面,在这个页面中,写一个form表单,列一些输入框和选择框,最下面添加三个按钮,分别为 提交,重置,返回三个

2. 这个页面需要给form表单添加action属性值  ${pageContext.request.contextPath}/addUserServlet  ,提交按钮类型设置为submit类型,重置按钮设置为reset类型,返回按钮设置为

<a class="btn btn-default" href="${pageContext.request.contextPath}/findUserByPageServlet">返回</a>

3. 添加一个AddUserServlet,首先获取request的编码类型为utf-8 ,防止了乱码,获取提交表单的Map键值对集合,返回为map

4. 将map封装为User的对象user

5. 调用UserService对象service的addUser()方法,将user作为其参数

6. service层的addUser方法,用来调用dao层的add方法向数据库的表添加一条数据

7. dao层的add方法 执行sql语句 insert into user values(null,?,?,?,?,?,?,null,null)  ,然后根据传给add的参数user对象,来添加各自参数

8. 最后直接跳转到FindUserByPageServlet

 

代码实现

add.jsp页面

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<!-- HTML5文档-->
<!DOCTYPE html>
<!-- 网页使用的语言 -->
<html lang="zh-CN">
<head>
    <!-- 指定字符集 -->
    <meta charset="utf-8">
    <!-- 使用Edge最新的浏览器的渲染方式 -->
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <!-- viewport视口:网页可以根据设置的宽度自动进行适配,在浏览器的内部虚拟一个容器,容器的宽度与设备的宽度相同。
    width: 默认宽度与设备的宽度相同
    initial-scale: 初始的缩放比,为1:1 -->
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <!-- 上述3个meta标签*必须*放在最前面,任何其他内容都*必须*跟随其后! -->
    <title>添加用户</title>

    <!-- 1. 导入CSS的全局样式 -->
    <link href="css/bootstrap.min.css" rel="stylesheet">
    <link href="css/add.css" rel="stylesheet">
    <!-- 2. jQuery导入,建议使用1.9以上的版本 -->
    <script src="js/jquery-2.1.0.min.js"></script>
    <!-- 3. 导入bootstrap的js文件 -->
    <script src="js/bootstrap.min.js"></script>
    <script src="js/表单验证.js"></script>
</head>
<body>
<div class="container">
    <center><h3>添加联系人页面</h3></center>
    <form action="${pageContext.request.contextPath}/addUserServlet"  method="post" id="form">
        <div class="form-group">
            <label for="name">姓名:</label>
            <input type="text" class="form-control" id="name" name="name" placeholder="请输入姓名">
        </div>

        <div class="form-group">
            <label>性别:</label>
            <input type="radio" name="gender" value="男" checked="checked"/>男
            <input type="radio" name="gender" value="女"/>女
        </div>

        <div class="form-group">
            <label for="age">年龄:</label>
            <input type="text" class="form-control" id="age" name="age" placeholder="请输入年龄">
            <span id="s_age" class="error"></span>
        </div>

        <div class="form-group">
            <label for="address">籍贯:</label>
            <select name="address" class="form-control" id="address">
                <option value="广东">广东</option>
                <option value="广西">广西</option>
                <option value="湖南">湖南</option>
            </select>
        </div>

        <div class="form-group">
            <label for="qq">QQ:</label>
            <input type="text" class="form-control" id="qq" name="qq" placeholder="请输入QQ号码"/>
            <span id="s_qq" class="error"></span>
        </div>

        <div class="form-group">
            <label for="email">Email:</label>
            <input type="text" class="form-control" id="email" name="email" placeholder="请输入邮箱地址"/>
            <span id="s_email" class="error"></span>
        </div>

        <div class="form-group" style="text-align: center">
            <input class="btn btn-primary"  type="submit" value="提交" />
            <input class="btn btn-default"  type="reset" value="重置" />
            <a class="btn btn-default" href="${pageContext.request.contextPath}/findUserByPageServlet">返回</a>
        </div>
    </form>
</div>
</body>
</html>

然后写AddUserServlet

package zr.web.userlist.web.Servlet;

import org.apache.commons.beanutils.BeanUtils;
import zr.web.userlist.domain.User;
import zr.web.userlist.service.UserService;
import zr.web.userlist.service.impl.UserServiceImpl;

import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.io.IOException;
import java.lang.reflect.InvocationTargetException;
import java.util.Map;

@WebServlet("/addUserServlet")
public class AddUserServlet extends HttpServlet {
    protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        //1. 设置编码
        request.setCharacterEncoding("utf-8");
        //2. 获取参数
        Map<String, String[]> map = request.getParameterMap();
        //3. 封装对象
        User user=new User();
        try {
            BeanUtils.populate(user,map);
        } catch (IllegalAccessException e) {
            e.printStackTrace();
        } catch (InvocationTargetException e) {
            e.printStackTrace();
        }

        //4. 调用Service保存

        UserService service=new UserServiceImpl();
        service.addUser(user);

        //5. 直接跳转到FindUserByPageServlet

        response.sendRedirect(request.getContextPath()+"/findUserByPageServlet");
    }

    protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
        this.doPost(request, response);
    }
}

service层

接口

    /**
     * 添加一个user
     * @param user
     */
    void addUser(User user);

实现方法

    @Override
    public void addUser(User user) {
        //1. 调用dao中的add方法,向数据库中添加一条数据
        dao.add(user);
    }

dao层

接口

    /**
     * 向数据库中添加一条数据
     * @param user
     */

    void add(User user);

实现

    @Override
    public void add(User user) {
        // 1. 定义sql语句

        String sql="insert into user values(null,?,?,?,?,?,?,null,null)";

        //2. 执行sql
        template.update(sql,user.getName(),user.getGender(),user.getAge(),user.getAddress(),user.getQq(),user.getEmail());

    }

全选按钮

1. 第一个checkbox的id命名为 firstCheckBox

2. 后面的checkbox命名为checked

3. 分别获取上面这两个id值,第一个id获取后获取其单击事件

4. 第二个id获取的为一个数组

5. 在单击事件函数中,使得后面每一个checkbox状态与第一个checkbox状态一样‘’

 

js代码如下

            //1. 获取第一个cb
            document.getElementById("firstCheckBox").onclick=function () {
                //2. 获取下边列表中所有的cb
                var cbs=document.getElementsByName("checked");
                //3. 遍历
                for (var i = 0; i <cbs.length ; i++) {
                    //4. 设置这些cbs[i]的checked状态=firstCheckBox.checked

                    cbs[i].checked=this.checked;
                }
            }
        }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值