课程删除

1、所需删除信息内容说明

课程基本信息、描述信息、章节信息、小节信息、小节里还包括视频,删除课程时删除所有信息。

2、删除课程的接口

(1)在EduCourseController添加删除课程(以及相关信息)方法

java 复制代码
@ApiOperation(value = "删除课程(以及相关信息)")
@DeleteMapping("{courseId}")
public R deleteCourse(@PathVariable String courseId){
    courseService.deleteCourse(courseId);
    return R.ok();
}

(2)在EduCourseService添加接口

java 复制代码
void deleteCourse(String courseId);

(3)在EduCourseServiceImpl实现接口方法

java 复制代码
//删除课程(以及相关信息)
@Override
public void deleteCourse(String courseId) {
    //1根据课程id删除小节
    //TODO 删除小节前删除视频
    QueryWrapper<EduVideo> wrapperVideo = new QueryWrapper<>();
    wrapperVideo.eq("course_id",courseId);
    videoService.remove(wrapperVideo);
    //2根据课程id删除章节
    QueryWrapper<EduChapter> wrapperChapter = new QueryWrapper<>();
    wrapperChapter.eq("course_id",courseId);
    chapterService.remove(wrapperChapter);
    //3根据课程id删除描述
    courseDescriptionService.removeById(courseId);
    //4根据课程id删除课程
    int delete = baseMapper.deleteById(courseId);
    if(delete==0){
        throw  new GuliException(20001,"删除课程失败");
    }

}

3、整合前端

(1)在api/course.js中添加删除课程的接口方法

java 复制代码
//删除课程方法
  deleteCourse(courseId){
    return request({
      url: `/eduservice/educourse/${courseId}`,
      method: 'delete'
    })
  }

(2)修改course/list.vue页面,调用删除课程接口方法

java 复制代码
<el-button type="text" @click="removeCourseId(scope.row.id)" size="mini" icon="el-icon-delete">删除</el-button>

(3)在course/list.vue页面实现删除课程js方法

java 复制代码
//删除课程(以及相关信息)
    removeCourseId(id) {
        this.$confirm("此操作将永久删除该课程, 是否继续?", "提示", {
        confirmButtonText: "确定",
        cancelButtonText: "取消",
        type: "warning"
      })
        .then(() => {
          //调用接口删除数据
          course.deleteCourse(id).then(response => {
            //提示
            this.$message({
              type: "success",
              message: "删除成功!"
            });
            //刷新表格
            this.getCourseList();
          });
        })
    }
相关推荐
七牛开发者2 小时前
HTML is the new Markdown:来自 Claude Code 团队的实践
前端·人工智能·语言模型·html
@大迁世界2 小时前
43.HTML 事件处理和 React 事件处理有什么区别?
前端·javascript·react.js·html·ecmascript
ZC跨境爬虫3 小时前
跟着 MDN 学 HTML day_38:(DocumentFragment 文档片段接口详解)
前端·javascript·ui·html·音视频
@大迁世界4 小时前
41.ShadCN 是什么?它如何和 Tailwind CSS 集成,从而更容易构建可访问且可自定义的 React 组件?
前端·javascript·css·react.js·前端框架
xiangxiongfly9156 小时前
Vue3 根据角色权限动态加载路由
前端·javascript·vue.js·动态加载路由
Aolith6 小时前
我是怎么把个人论坛首页性能从80分优化到100分的(附踩坑全记录)
vue.js·性能优化
容智信息7 小时前
AI Agent(智能体)的输出格式应该从 Markdown 转向 HTML吗?
前端·人工智能·rust·编辑器·html·prompt
Amy_yang7 小时前
uni-app 安卓端纯前端预览 DOCX 的实现思路
前端·vue.js
xiangxiongfly9157 小时前
Vue3 动态加载静态资源
前端·javascript·vue.js
克里斯蒂亚诺更新7 小时前
ruoyi切换新版本初始化需要修改的地方
前端·javascript·vue.js