前端以该格式<tr><td><input type="checkbox" class="c1"></td><td>01(pid)</td><td>毛巾(pname)</td><td>生活用品(cname)</td><td><form action="deleteProductByPid.action">展示数据库信息,数据库有两个表,类别表category表里有cid和cname,商品表product表里有pid、pname和外键cid。该需求的前端和后端代码
时间: 2023-08-14 20:29:03 浏览: 108
使用<input>实现checkbox
好的,以下是一个简单的前端和后端代码示例:
前端代码(使用jQuery库):
```html
<!DOCTYPE html>
<html>
<head>
<title>商品列表</title>
</head>
<body>
<table>
<thead>
<tr>
<th></th>
<th>编号</th>
<th>商品名称</th>
<th>商品类别</th>
<th>操作</th>
</tr>
</thead>
<tbody id="product-list">
<!-- 商品信息的展示 -->
</tbody>
</table>
<button id="delete-selected">删除选中</button>
<script src="https://code.jquery.com/jquery-3.6.0.min.js"></script>
<script>
$(document).ready(function() {
// 在页面加载完成后,向后端请求商品列表,并展示到页面上
$.get("/getProductList", function(data) {
var productList = "";
for (var i = 0; i < data.length; i++) {
var product = data[i];
productList += "<tr>";
productList += "<td><input type='checkbox' class='c1' value='" + product.pid + "'></td>";
productList += "<td>" + product.pid + "</td>";
productList += "<td>" + product.pname + "</td>";
productList += "<td>" + product.cname + "</td>";
productList += "<td><button class='delete-product' data-pid='" + product.pid + "'>删除</button></td>";
productList += "</tr>";
}
$("#product-list").html(productList);
});
// 监听删除按钮的点击事件,发送删除请求到后端
$("#delete-selected").on("click", function() {
var selectedProducts = [];
$(".c1:checked").each(function() {
selectedProducts.push($(this).val());
});
if (selectedProducts.length == 0) {
alert("请选择要删除的商品");
return;
}
if (!confirm("确定要删除选中的商品吗?")) {
return;
}
$.post("/deleteProducts", { pids: selectedProducts }, function(data) {
if (data.success) {
alert("删除成功");
window.location.reload();
} else {
alert("删除失败:" + data.message);
}
});
});
// 监听单个删除按钮的点击事件,发送删除请求到后端
$("#product-list").on("click", ".delete-product", function() {
var pid = $(this).data("pid");
if (!confirm("确定要删除编号为" + pid + "的商品吗?")) {
return;
}
$.post("/deleteProduct", { pid: pid }, function(data) {
if (data.success) {
alert("删除成功");
$(this).closest("tr").remove();
} else {
alert("删除失败:" + data.message);
}
}.bind(this));
});
});
</script>
</body>
</html>
```
在这个示例中,我们使用jQuery库来简化前端代码的编写。页面加载完成后,我们向后端发送一个GET请求,获取商品列表数据,并将数据展示到页面上。同时,我们为每个商品添加了一个复选框和一个删除按钮,当用户勾选复选框并点击删除按钮时,会向后端发送一个POST请求,请求地址为`/deleteProduct`或`/deleteProducts`,具体请求地址根据是否选择了多个商品进行删除而不同。需要注意的是,这个示例中并没有展示如何从数据库中获取商品信息的后端代码,因此在实际应用中,您还需要编写后端代码来处理请求并返回商品信息。此外,这个示例中的样式也非常简陋,您可以根据实际需求添加更多的样式和交互效果。
后端代码(使用Java语言和Spring框架):
```java
@Controller
public class ProductController {
@Autowired
private ProductService productService;
@GetMapping("/getProductList")
@ResponseBody
public List<Product> getProductList() {
return productService.getAllProducts();
}
@PostMapping("/deleteProduct")
@ResponseBody
public Map<String, Object> deleteProduct(@RequestParam("pid") String pid) {
Map<String, Object> result = new HashMap<>();
try {
productService.deleteProductByPid(pid);
result.put("success", true);
} catch (Exception e) {
result.put("success", false);
result.put("message", e.getMessage());
}
return result;
}
@PostMapping("/deleteProducts")
@ResponseBody
public Map<String, Object> deleteProducts(@RequestParam("pids") String[] pids) {
Map<String, Object> result = new HashMap<>();
try {
productService.deleteProductsByPid(pids);
result.put("success", true);
} catch (Exception e) {
result.put("success", false);
result.put("message", e.getMessage());
}
return result;
}
}
@Service
public class ProductService {
@Autowired
private ProductDao productDao;
public List<Product> getAllProducts() {
return productDao.getAllProducts();
}
public void deleteProductByPid(String pid) {
productDao.deleteProductByPid(pid);
}
public void deleteProductsByPid(String[] pids) {
productDao.deleteProductsByPid(pids);
}
}
@Repository
public class ProductDao {
@Autowired
private JdbcTemplate jdbcTemplate;
public List<Product> getAllProducts() {
return jdbcTemplate.query("SELECT p.*, c.cname FROM product p JOIN category c ON p.cid = c.cid", new ProductRowMapper());
}
public void deleteProductByPid(String pid) {
jdbcTemplate.update("DELETE FROM product WHERE pid = ?", pid);
}
public void deleteProductsByPid(String[] pids) {
String[] placeholders = new String[pids.length];
Arrays.fill(placeholders, "?");
String sql = "DELETE FROM product WHERE pid IN (" + String.join(",", placeholders) + ")";
jdbcTemplate.update(sql, (Object[]) pids);
}
private class ProductRowMapper implements RowMapper<Product> {
@Override
public Product mapRow(ResultSet rs, int rowNum) throws SQLException {
Product product = new Product();
product.setPid(rs.getString("pid"));
product.setPname(rs.getString("pname"));
product.setCname(rs.getString("cname"));
return product;
}
}
}
public class Product {
private String pid;
private String pname;
private String cname;
// 省略getter/setter方法
}
```
在这个示例中,我们使用Java语言和Spring框架来编写后端代码。我们将前端发送的请求映射到对应的Controller方法中,并在Controller方法中调用Service方法来处理业务逻辑。Service方法中调用Dao方法来访问数据库。需要注意的是,这个示例中并没有展示如何配置Spring框架的相关配置文件,因此在实际应用中,您还需要编写相关配置文件来配置Spring框架。同时,这个示例中的Dao层使用了JdbcTemplate来简化访问数据库的代码,您也可以使用其他ORM框架来完成数据访问。
阅读全文