黑马javaweb最后的作业的修改和删除部分代码

itheima的javaWeb课程最后留下了一个修改和删除品牌的空子,然后下面是我的实现方式。

一、修改逻辑 

1. 前端界面

点击修改就会跳入brandShow的函数中

 <template slot-scope="scope">
       <el-row>
            <el-button type="primary" @click="brandShow(scope.row) ">修改</el-button>
             <el-button type="danger" @click="deleteById(scope.row.id)">删除</el-button>
       </el-row>
</template>

brandShow函数定义如下:

brandShow(row) {
       // 获取数据
       this.brandSelect = row;
       console.log(this.brand);
       // 弹出窗口
       this.updateDialogVisible = true;
       console.log(this.updateDialogVisible);
       this.selectAll();
},

会发现,我又定义了一个新的模型,brandSelect,它和新的表单相对应,所以完整的前端代码就是:

 <!--修改表单-->
    <el-dialog

            title="修改品牌"
            :visible.sync="updateDialogVisible"
            width="30%"
    >

        <el-form ref="form" :model="brandSelect" label-width="80px">
            <el-form-item label="品牌名称">
                <el-input  v-model="brandSelect.brandName"></el-input>
            </el-form-item>

            <el-form-item label="企业名称">
                <el-input v-model="brandSelect.companyName"></el-input>
            </el-form-item>

            <el-form-item label="排序">
                <el-input v-model="brandSelect.ordered"></el-input>
            </el-form-item>

            <el-form-item label="备注">
                <el-input type="textarea" v-model="brandSelect.description"></el-input>
            </el-form-item>

            <el-form-item label="状态">
                <el-switch v-model="brandSelect.status"
                           active-value="1"
                           inactive-value="0"></el-switch>
            </el-form-item>

            <el-form-item>
                <el-button type="primary" @click="update">提交</el-button>
                <el-button @click="updateDialogVisible = false">取消 </el-button>
            </el-form-item>
        </el-form>

    </el-dialog>

点击提交触发update方法,该函数定义是:

update(){
                var _this = this;
                axios({
                    method:"post",
                    url:"http://localhost:8080/brand-demo1/brand/update",
                    data:_this.brandSelect //这是提交的表单数据
                }).then(function (resp){
                    //这里是success数据
                    if(resp.data == "success"){
                        //添加成功
                        _this.updateDialogVisible = false;
                        console.log("修改成功!");
                        //重新查询数据进行显示
                        _this.selectAll();
                        _this.$message({
                            message: '恭喜你,修改成功',
                            type: 'success'
                        });
                    }
                    if(resp.data == "fail"){
                        _this.$message.error('修改失败');
                    }
                })
            },

2.后台部分

public void update(Brand brand) {
        //调用BrandMapper.selectAll()
        SqlSession sqlSession = factory.openSession();
        BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);

        mapper.update(brand);
        //提交事务
        sqlSession.commit();
        sqlSession.close();

    }

二、删除逻辑

1.前台部分

 <template slot-scope="scope">
       <el-row>
            <el-button type="primary" @click="brandShow(scope.row) ">修改</el-button>
             <el-button type="danger" @click="deleteById(scope.row.id)">删除</el-button>
       </el-row>
</template>

点击删除,调用一个deleteById的方法

deleteById(id){
                console.log(id);
                this.selectId = id;
                var _this = this;
                axios({
                    method:"post",
                    url:"http://localhost:8080/brand-demo1/brand/deleteById?id="+this.selectId
                }).then(function (resp){
                    //这里是success数据
                    if(resp.data == "success"){
                        //添加成功
                        _this.updateDialogVisible = false;
                        //重新查询数据进行显示
                        _this.selectAll();
                        _this.$message({
                            message: '恭喜你,删除成功',
                            type: 'success'
                        });
                    }
                    if(resp.data == "fail"){
                        _this.$message.error('删除失败');
                    }
                })
            },

2.后台部分

 @Override
    public void deleteById(int id) {
        SqlSession sqlSession = factory.openSession();
        BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);
        mapper.deleteById(id);
        //提交事务
        sqlSession.commit();
        sqlSession.close();
    }

  • 13
    点赞
  • 49
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 15
    评论
好的,修改密码的实现代码如下: 1. 修改密码页面的 HTML 代码: ```html <form action="updatePassword" method="post"> <label for="oldPassword">旧密码:</label> <input type="password" id="oldPassword" name="oldPassword"><br> <label for="newPassword">新密码:</label> <input type="password" id="newPassword" name="newPassword"><br> <label for="confirmPassword">确认新密码:</label> <input type="password" id="confirmPassword" name="confirmPassword"><br> <button type="submit">确认修改</button> </form> ``` 2. 修改密码的 Servlet 代码: ```java @WebServlet("/updatePassword") public class UpdatePasswordServlet extends HttpServlet { protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { // 获取旧密码、新密码、确认新密码 String oldPassword = request.getParameter("oldPassword"); String newPassword = request.getParameter("newPassword"); String confirmPassword = request.getParameter("confirmPassword"); // 获取当前登录用户的信息 HttpSession session = request.getSession(); User user = (User) session.getAttribute("user"); // 验证旧密码是否正确 if (!user.getPassword().equals(oldPassword)) { response.getWriter().println("<script>alert('旧密码不正确!');history.go(-1);</script>"); return; } // 验证新密码和确认新密码是否一致 if (!newPassword.equals(confirmPassword)) { response.getWriter().println("<script>alert('新密码和确认新密码不一致!');history.go(-1);</script>"); return; } // 修改密码 UserService userService = new UserServiceImpl(); boolean result = userService.updatePassword(user.getId(), newPassword); if (result) { response.sendRedirect("login.jsp"); } else { response.getWriter().println("<script>alert('修改密码失败!');history.go(-1);</script>"); } } } ``` 3. UserServiceImpl 中的 updatePassword 方法代码: ```java public boolean updatePassword(int userId, String newPassword) { Connection conn = null; PreparedStatement pstmt = null; try { conn = JDBCUtils.getConnection(); String sql = "update user set password = ? where id = ?"; pstmt = conn.prepareStatement(sql); pstmt.setString(1, newPassword); pstmt.setInt(2, userId); int count = pstmt.executeUpdate(); return count > 0; } catch (SQLException e) { e.printStackTrace(); } finally { JDBCUtils.close(conn, pstmt); } return false; } ``` 注意:以上代码仅供参考,具体实现可能因为业务需求而有所不同。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

GallagherZ

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值