Spring Boot实现标签分页

本文档详细介绍了如何在Spring Boot项目中实现标签的分页功能,涵盖了环境配置、项目结构、Controller、Service接口及其实现,以及相关的HTML页面代码片段。
摘要由CSDN通过智能技术生成

实现标签分页

环境

  1. MySql 5.0.67
  2. Spring Boot 2.3.1
  3. mysql-connector-java 5.1.37
  4. Type字段有idname

项目结构

在这里插入图片描述

TypeController

@Controller
@RequestMapping("/admin/types")
public class TypeController {

    @Autowired
    private ITypeService iTypeService;

    @GetMapping
    public String list(@PageableDefault(size = 5, sort = {"id"}, direction = Sort.Direction.DESC) Pageable pageable, Model model) {
        Page<Type> page = iTypeService.listType(pageable);
        model.addAttribute("page", page);
        return "admin/types";
    }

    //@{/admin/type/{id}/delete(id=${types.id})}
    @GetMapping("{id}/delete")
    public String delete(@PathVariable Long id) {
        iTypeService.deleteType(id);
        return "redirect:/admin/types";
    }

    @GetMapping("input")
    public String input(){
        return "admin/types-input";
    }

    @PostMapping("add")
    public String add(Type type){
        iTypeService.addType(type);
        return "redirect:/admin/types";
    }

    @GetMapping("{id}/toUpdate")
    public String toUpdate(@PathVariable Long id, Model model){
        Type type = iTypeService.getTypeById(id);
        model.addAttribute("type", type);
        return  "admin/types-input";
    }

    @PostMapping("update/{id}")
    public String update(Type type, @PathVariable Long id){
        iTypeService.update(id, type);
        return "redirect:/admin/types";
    }
}

ITypeService

public interface ITypeService {
    Page<Type> listType(Pageable pageable);

    void deleteType(Long id);

    void addType(Type type);

    Type getTypeById(Long id);

    void update(Long id, Type type);
}

TypeServiceImpl

@Service
public class TypeServiceImpl implements ITypeService {

    @Autowired
    private TypeDao typeDao;

    @Override
    public Page<Type> listType(Pageable pageable) {
        return typeDao.findAll(pageable);
    }

    @Override
    public void deleteType(Long id) {
        typeDao.deleteById(id);
    }

    @Override
    public void addType(Type type) {
        typeDao.save(type);
    }

    @Override
    public Type getTypeById(Long id) {
        return typeDao.getOne(id);
    }

    @Override
    public void update(Long id, Type type) {
        Type type1 = typeDao.getOne(id);
        BeanUtils.copyProperties(type, type1);
        typeDao.save(type);
    }
}

Type.html 部分代码

<tr th:each="type,iterStat : ${page.content}">
      <td th:text="${iterStat.count}">1</td>
      <td th:text="${type.name}">刻意练习清单</td>
      <td>
            <a href="#" th:href="@{/admin/types/{id}/toUpdate(id=${type.id})}" class="ui mini teal basic button">编辑</a>
            <a href="#" th:href="@{/admin/types/{id}/delete(id=${type.id})}"  class="ui mini red basic button">删除</a>
      </td>
</tr>

Type-input.html 部分代码

<form action="#" method="post" th:action="*{id}==null ? @{/admin/types/add} : @{/admin/types/update/{id}(id=*{id})}" class="ui form">
    <input type="hidden" name="id" th:value="*{id}">
    <div class=" field">
        <div class="ui left labeled input">
            <label class="ui teal basic label">名称</label>
            <input type="text" name="name" placeholder="分类名称" th:value="*{name}">
        </div>
    </div>
    <div class="ui error message"></div>
    <div class="ui right aligned container">
        <button type="button" class="ui button" onclick="window.history.go(-1)">返回</button>
        <button class="ui teal submit button">提交</button>
    </div>
</form>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值