当前位置: 首页 > news >正文

网站制作的评价标准eclipse 网站开发教程

网站制作的评价标准,eclipse 网站开发教程,营销型网站的建站步骤是什么意思,兰州官网seo诊断原文地址#xff1a;前后端开发之——文章分类管理 - Pleasure的博客 下面是正文内容#xff1a; 前言 上回书说到 文章管理系统之添加文章分类。就是通过点击“新建文章分类”按钮从而在服务端数据库中增加一个文章分类。 对于文章分类这个对象#xff0c;增删改查属于配…原文地址前后端开发之——文章分类管理 - Pleasure的博客 下面是正文内容 前言 上回书说到 文章管理系统之添加文章分类。就是通过点击“新建文章分类”按钮从而在服务端数据库中增加一个文章分类。 对于文章分类这个对象增删改查属于配套的基础操作。这篇博文就主要聚焦于“增”之外的“删改查”配套操作。这里的查不是指搜索而是指查询数据库信息用于前端显示。 前端使用语言Vue后端使用语言SpringBoot 正文 前端思路分析 当用户点击界面上的按钮后跳出之前的弹窗 修改完相关信息后点击确认触发按钮绑定的updateCategory函数向后端发送表单 updateCategory函数在开头的script部分进行了声明是调用后端修改文章分类接口的异步函数 updateCategory函数中的articleCategoryUpdateService服务在api文件夹下的article.js文件中进行了定义以put的方式向后端“/category”发送idcategoryNamecategoryAlias的值用来修改数据库中的记录。 “删”同理点击按钮触发deleteCategory函数。 函数弹窗表单接口都有自己对应的代码 后端思路分析 后端文件结构需要查看专栏之前的文章这里就不重复进行申明了 数据访问层CategoryMapper.java定义CategoryMapper函数用于向数据库添加数据 服务层CategoryService.java中先声明接口然后在CategoryServiceImpl.java中定义CategoryService函数通过调用ControllerMapper函数实现添加不要忘记在pojo文件夹下声明Category类 请求层CategoryController.java调用服务层的函数categoryService.add(category)通过post/get/put等不同的方式实现添加。 需要注意的是 由于新增文章分类的时候向后端发送的json文件不携带id字段是由数据库中的id主键自动生成而更新和删除操作向后端发送的json文件则需要携带所以在pojo文件夹下声明Category类时需要进行注解分组校验。 页面展示 实现代码 部分项目结构和代码需要参考专栏之前的文章 前端Vue categorys和categoryModel的声明略 采用了element-plus的UI交互组件官方参考文档Overview 组件总览 | Element Plus 根据自己的需要自行拼接 api文件夹下的article.js接口删除操作相对于新增需要额外携带id字段作为区别 import request from /utils/request.js export const articleCategoryListService (){return request.get(/category) } //文章分类添加 export const articleCategoryAddService (categoryData){return request.post(/category,categoryData) } //文章分类修改 export const articleCategoryUpdateService (categoryData){return request.put(/category,categoryData) } //文章分类删除 export const articleCategoryDeleteService (id){return request.delete(/category?idid) } 声明要用到的异步函数放在script部分 /声明一个异步的函数 import { articleCategoryListService, articleCategoryAddService, articleCategoryUpdateService, articleCategoryDeleteService } from /api/article.js const articleCategoryList async () {let result await articleCategoryListService();categorys.value result.data;} articleCategoryList(); 显示文章分类的函数放在script部分 //定义变量,控制标题的展示 const title ref()const showDialog (row) {dialogVisible.value true; title.value 编辑分类//数据拷贝categoryModel.value.categoryName row.categoryName;categoryModel.value.categoryAlias row.categoryAlias;//扩展id属性,将来需要传递给后台,完成分类的修改categoryModel.value.id row.id } 编辑文章分类的函数放在script部分 //编辑分类 const updateCategory async () {//调用接口let result await articleCategoryUpdateService(categoryModel.value);ElMessage.success(result.msg ? result.msg : 编辑成功)//调用获取所有文章分类的函数articleCategoryList();dialogVisible.value false; }删除文章分类的弹窗和函数放在script部分 import { ElMessageBox } from element-plus const deleteCategory (row) {ElMessageBox.confirm(确认删除当前文章分类?,Warning,{confirmButtonText: OK,cancelButtonText: Cancel,type: warning,}).then(async () {//调用接口let result await articleCategoryDeleteService(row.id);ElMessage({type: success,message: Delete completed,})articleCategoryList();}).catch(() {ElMessage({type: info,message: Delete canceled,})}) } 页面显示部分即template部分包括了弹窗和表格 templateel-page-header :iconnulltemplate #contentdiv classflex items-centerel-avatar :size32 classmr-3srchttps://cube.elemecdn.com/0/88/03b0d39583f48206768a7534e55bcpng.png /span classtext-large font-600 mr-3 文章分类列表/span/div/templatetemplate #extrael-button typeprimary clickdialogVisible true; title 新建文章分类; clearData()新建文章分类/el-buttonel-dialog v-modeldialogVisible :titletitle width30%el-form :modelcategoryModel :rulesrules label-width100px stylepadding-right: 30pxel-form-item label文章分类名 propcategoryNameel-input v-modelcategoryModel.categoryName minlength1 maxlength10/el-input/el-form-itemel-form-item label备注和说明 propcategoryAliasel-input v-modelcategoryModel.categoryAlias minlength1 maxlength15/el-input/el-form-item/el-formtemplate #footerspan classdialog-footerel-button clickdialogVisible false取消/el-buttonel-button typeprimary clicktitle 新建文章分类 ? addCategory() : updateCategory() 确认 /el-button/span/template/el-dialog/template/el-page-headerel-divider/el-dividerel-table :datacategorys stylewidth: 100%el-table-column labelid propid /el-table-column label分类名称 propcategoryName/el-table-columnel-table-column label分类别名 propcategoryAlias/el-table-columnel-table-column label操作 width100template #default{ row }el-button :iconEdit circle plain typeprimary clickshowDialog(row)/el-buttonel-button :iconDelete circle plain typedanger clickdeleteCategory(row)/el-button/template/el-table-columntemplate #emptyel-empty description没有数据 //template/el-table /template 后端SpringBoot 增删改查的操作上大体相同所以就合并进行展示了。 实体类Category.java package org.example.pojo;import com.fasterxml.jackson.annotation.JsonFormat; import jakarta.validation.constraints.NotEmpty; import jakarta.validation.constraints.NotNull; import jakarta.validation.groups.Default; import lombok.Data; import org.apache.ibatis.annotations.Update; import java.time.LocalDateTime;Data public class Category {NotNull(groups Update.class)private Integer id;//主键IDNotEmpty/*(groups {Add.class, Update.class})*/private String categoryName;//分类名称NotEmpty/*(groups {Add.class, Update.class})*/private String categoryAlias;//分类别名private Integer createUser;//创建人IDJsonFormat(pattern yyyy-MM-dd HH:mm:ss)private LocalDateTime createTime;//创建时间JsonFormat(pattern yyyy-MM-dd HH:mm:ss)private LocalDateTime updateTime;//更新时间public interface Add extends Default {}public interface Update extends Default{} }请求层CategoryController.java package org.example.controller;import org.apache.ibatis.annotations.Mapper; import org.example.pojo.Result; import org.example.pojo.Category; import org.example.service.CategoryService; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*;import java.util.List;RestController RequestMapping(/category) public class CategoryController {Autowiredprivate CategoryService categoryService;PostMappingpublic Result add(RequestBody Validated(Category.Add.class) Category category){categoryService.add(category);return Result.success();}GetMappingpublic ResultListCategory list(){ListCategory cs categoryService.list();return Result.success(cs);}GetMapping(/detail)public ResultCategory detail(Integer id){Category c categoryService.findById(id);return Result.success(c);}PutMappingpublic Result update(RequestBody Validated(Category.Update.class) Category category){categoryService.update(category);return Result.success();}DeleteMappingpublic Result delete(Integer id){categoryService.deleteById(id);return Result.success();} }服务层CategoryServiceImpl.javaCategoryService.java只需进行声明函数略 package org.example.service.impl;import org.example.mapper.CategoryMapper; import org.example.pojo.Category; import org.example.service.CategoryService; import org.example.utils.ThreadLocalUtil; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; import java.time.LocalDateTime; import java.util.List; import java.util.Map;Service public class CategoryServiceImpl implements CategoryService {Autowiredprivate CategoryMapper categoryMapper;Overridepublic void add(Category category){category.setCreateTime(LocalDateTime.now());category.setUpdateTime(LocalDateTime.now());MapString,Object map ThreadLocalUtil.get();Integer userId (Integer) map.get(id);category.setCreateUser(userId);categoryMapper.add(category);}Overridepublic ListCategory list(){MapString,Object map ThreadLocalUtil.get();Integer userId (Integer) map.get(id);return categoryMapper.list(userId);}Overridepublic Category findById(Integer id) {Category c categoryMapper.findById(id);return c;}Overridepublic void update(Category category){category.setUpdateTime(LocalDateTime.now());categoryMapper.update(category);}Overridepublic void deleteById(Integer id){categoryMapper.deleteById(id);} }数据访问层CategoryMapper.java package org.example.mapper; import org.apache.ibatis.annotations.*; import org.example.pojo.Category; import java.util.List; Mapper public interface CategoryMapper {Insert(insert into category(category_name,category_alias,create_user,create_time,update_time) values (#{categoryName},#{categoryAlias},#{createUser},#{createTime},#{updateTime}))void add(Category category);Select(select * from category where create_user #{userId})ListCategory list(Integer userId);Select(select * from category where id #{id})Category findById(Integer id);Update(update category set category_name#{categoryName},category_alias#{categoryAlias},update_timenow() where id#{id})void update(Category category);Delete(delete from category where id#{id})void deleteById(Integer id); }尾声 一周一码后面就是文章管理的部分了。
http://www.tj-hxxt.cn/news/228830.html

相关文章:

  • 百度广州给做网站公司南宁seo服务公司
  • 网站过期就可以抢注怎么用vs做网站
  • 武邑网站建设公司html代码软件
  • 河北网站建设口碑好wordpress自动标签页
  • 深圳高端建设网站app推广代理
  • 成都隆昌网站建设做互联网产品和运营必备的网站
  • 会员视频网站建设张家港做网站收费标准
  • 可以免费做网站推广的平台机械公司简介模板
  • 电商设计网站模板全国工程信息网
  • 网站建设查询php企业网站后台管理系统
  • 电视剧百度风云榜seo自动推广工具
  • 网站建设过程中应该注意的事项有株洲市民健康提醒
  • 长治县网站建设delphi做网站开发
  • 湛江网站建设模板定位工厂网站建设详细的步骤有哪些
  • 部队网站建设报告网站的平面设计图用ps做
  • 公司网站设计专业的seo的五个步骤
  • 做网站好看的背景图片优质手机网站建设哪家好
  • 简易网站制作旅游景点网站模板
  • 广东深圳网站wordpress 杂志
  • 网站描述怎样写大宗贸易采购平台
  • 微商城手机网站制作品牌全案策划案例
  • 做网站好还是阿里巴巴好大连巨人网络推广有限公司
  • 网站建设费用请示黑龙江网站备案查询
  • 可以免费做中考题的网站网站内套网站代码
  • 如何修改网站图片怎么制作网页投票软件
  • 哪个网站是动态谷歌网站推广方案
  • 四川建设厅官方网站是多少广东阳江房产网
  • 网站建设丿找vx cp5173更多标签的适用场景
  • 房产网站建设产品网站版本功能列表
  • 网站顶端图片素材如何制作app的页面