修改数据的实现01--回显数据

为什么要回显数据?或者说什么是回显数据?
回显就是对指定数据的修改,先完全展示其信息,才方便修改。其实就是获取到用户点击数据的id,根据id将其内容使用jsp进行输出。像下面,就是取到了三只松鼠的id,对他进行展示。

在这里插入图片描述

难点:确定id
大体实现步骤:写接口–写SQL–写service层代码–用户点击一条数据进行修改(a标签)–拿到id,跳转到servlet–调用selectById方法,参数是id–接收到对象–传到展示的jsp界面。其实就比平常多了一个最后的展示环节。
一共分为:4个步骤

mybatis部分

接口:

    //根据id查询
    Brand selectByIdBrand(int id);

sql:

<!--    根据id查询-->
    <select id="selectByIdBrand" resultMap="BrandResultMap">
        select * from tb_brand
        where id = #{id}
    </select>

二、service部分

//    根据id查询
    public Brand SelectById(int id){


    //获取sqlSession
    SqlSession sqlSession = sqlSessionFactory.openSession();

    //调用getMapper
    BrandMapper mapper = sqlSession.getMapper(BrandMapper.class);

    //调用接口方法
    Brand brand = mapper.selectByIdBrand(id);

        //关闭连接
    sqlSession.close();

    return brand;
    }

三、确定用户点击的id是那一条并传入servlet

①确定id的关键代码:

 <a href="SelectByIdServlet?id=${brand.id}" class="btn btn-sm btn-primary mr-3">修改</a>

在这里插入图片描述

打个问好,写个id,这样即可跳转到servlet,又可以把id带过去,很受启发。之后用户点击每一条都可以进行跳转,接下来就是servlet部分,这一部分基本就回到正轨-----调方法,得对象。

②获取该id对应的对象值并将其转发到展示界面

package com.fldwws.web;

import com.fldwws.pojo.Brand;
import com.fldwws.service.BrandService;

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("/SelectByIdServlet")
public class SelectByIdServlet extends HttpServlet {
    @Override
    protected void service(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException {
        //接收id值
        String id = req.getParameter("id");

        //调用service方法
        BrandService brandService = new BrandService();
        Brand brand = brandService.SelectById(Integer.parseInt(id));

        //存储到request域中
        req.setAttribute("brand",brand);
        //转发
//        resp.sendRedirect("/update.jsp");
        req.getRequestDispatcher("/update.jsp").forward(req,resp);
    }
}

在这里插入图片描述

展示数据

展示的关键就是将input标签中的 value值写进去。
还有一个就是id也需要存进去,这里需要采用隐藏式提交
最后一个就是用户的radio表达需要先判断再进行输出

<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<%@ taglib uri="http://java.sun.com/jsp/jstl/core" prefix="c"%>

<!DOCTYPE html>
<html lang="en">

<head>
    <title>表单填写</title>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <link rel="stylesheet" href="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/css/bootstrap.min.css">
    <script src="https://cdn.staticfile.org/jquery/3.2.1/jquery.min.js"></script>
    <script src="https://cdn.staticfile.org/popper.js/1.15.0/umd/popper.min.js"></script>
    <script src="https://cdn.staticfile.org/twitter-bootstrap/4.3.1/js/bootstrap.min.js"></script>
</head>

<body>
<div class="container mt-5">
    <form action="ModifyServlet" method="post">
<%--        隐藏域提交id--%>
        <input type="hidden" name="id" value="${brand.id}">
        品牌名称:<input name="brandName" class="form-control" value="${brand.brandName}">
        企业名称:<input name="companyName" class="form-control" value="${brand.companyName}">
        价格: <input name="ordered" class="form-control" value="${brand.ordered}">
        描述:<textarea name="description" rows="5" cols="20" class="form-control">${brand.description}</textarea>
        状态:
        <c:if test="${brand.status == 1}">
            <input type="radio" name="status" value="1" class="mt-4" checked>启用
            <input type="radio" name="status" value="0" >禁用<br>
        </c:if>
        <c:if test="${brand.status == 0}">
            <input type="radio" name="status" value="1" class="mt-4" >启用
            <input type="radio" name="status" value="0" checked>禁用<br>
        </c:if>

        <button class="btn btn-primary " type="submit ">提交</button>
    </form>
</div>

</body>

</html>

在这里插入图片描述

  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
el-checkbox-group组件在回显数据时,官方文档中只支持绑定基础数据类型(string / number / boolean)。如果需要绑定数组对象结构的数据并进行回显,需要自行解决这个问题。其中,可以参考以下方法解决: 1. 修改源码:可以根据项目所使用的element-ui版本,找到对应版本的element-ui源码,并按照指定版本clone下来。然后找到checkbox组件的源代码(packages/checkbox/src/),对源码进行修改。目前的源码中仅使用了数组的indexOf方法进行处理,不满足我们的需求。因此,可以尝试修改源码,使其支持绑定数组对象结构的数据进行回显。 #### 引用[.reference_title] - *1* *3* [el-checkbox-group绑定数据为对象的回显问题](https://blog.csdn.net/wilsonfzh/article/details/123998398)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [vue <el-checkbox-group>多选框回显](https://blog.csdn.net/u014508939/article/details/126507322)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值