• 在线教育项目-day07【添加课程-填写课程基本信息2】


    因为一级,二级分类以及讲师已经拿到了,因为前端代码比较琐碎,最后会全粘出来

    这里再重新说一下一级二级下拉列表的实现

    前端页面

            <!-- 所属分类 TODO -->
            <el-form-item label="课程分类">
                <el-select
                    v-model="courseInfo.subjectParentId"
                    placeholder="一级分类" @change="subjectLevelOneChanged">
    
                    <el-option
                        v-for="subject in subjectOneList"
                        :key="subject.id"
                        :label="subject.title"
                        :value="subject.id"/>
    
                </el-select>
    
                <!-- 二级分类 -->
                <el-select v-model="courseInfo.subjectId" placeholder="二级分类">
                    <el-option
                        v-for="subject in subjectTwoList"
                        :key="subject.id"
                        :label="subject.title"
                        :value="subject.id"/>
                </el-select>
            </el-form-item>

    具体方法:

      //点击某个一级分类,触发change,显示对应二级分类
            subjectLevelOneChanged(value) {
                //value就是一级分类id值
                //遍历所有的分类,包含一级和二级
                for(var i=0;i<this.subjectOneList.length;i++) {
                    //每个一级分类
                    var oneSubject = this.subjectOneList[i]
                    //判断:所有一级分类id 和 点击一级分类id是否一样
                    if(value === oneSubject.id) {
                        //从一级分类获取里面所有的二级分类
                        this.subjectTwoList = oneSubject.children
                        //把二级分类id值清空
                        this.courseInfo.subjectId = ''
                    }
                }
            },
            //查询所有的一级分类
            getOneSubject() {
                subject.getSubjectList()
                    .then(response => {
                        this.subjectOneList = response.data.items
                    })
            },

    上传封面页面代码

            <el-form-item label="课程封面">
    
                <el-upload
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
                    :before-upload="beforeAvatarUpload"
                    :action="BASE_API+'/eduoss/file'"
                    class="avatar-uploader">
                    <img :src="courseInfo.cover">
                </el-upload>
    
            </el-form-item>

    页面函数

    //上传封面成功调用的方法
            handleAvatarSuccess(res, file) {
                this.courseInfo.cover = res.data.url
            },
            //上传之前调用的方法
            beforeAvatarUpload(file) {
                const isJPG = file.type === 'image/jpeg'
                const isLt2M = file.size / 1024 / 1024 < 2
    
                if (!isJPG) {
                    this.$message.error('上传头像图片只能是 JPG 格式!')
                }
                if (!isLt2M) {
                    this.$message.error('上传头像图片大小不能超过 2MB!')
                }
                return isJPG && isLt2M
            },

    实现上传封面

    前端代码:

    ui:

            <!-- 课程封面-->
            <el-form-item label="课程封面">
    
                <el-upload
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
                    :before-upload="beforeAvatarUpload"
                    :action="BASE_API+'/eduoss/file/upload'"
                    class="avatar-uploader">
                    <img :src="courseInfo.cover">
                </el-upload>

    方法

            //上传封面成功调用的方法
            handleAvatarSuccess(res, file) {
                this.courseInfo.cover = res.data.url
            },
            //上传之前调用的方法
            beforeAvatarUpload(file) {
                const isJPG = file.type === 'image/jpeg'
                const isLt2M = file.size / 1024 / 1024 < 2
    
                if (!isJPG) {
                    this.$message.error('上传头像图片只能是 JPG 格式!')
                }
                if (!isLt2M) {
                    this.$message.error('上传头像图片大小不能超过 2MB!')
                }
                return isJPG && isLt2M
            },

    方法之前已经写过了

    最终页面代码如下

    <template>
    
      <div class="app-container">
    
        <h2 style="text-align: center;">发布新课程</h2>
    
        <el-steps :active="1" process-status="wait" align-center style="margin-bottom: 40px;">
          <el-step title="填写课程基本信息"/>
          <el-step title="创建课程大纲"/>
          <el-step title="最终发布"/>
        </el-steps>
    
        <el-form label-width="120px">
    
            <el-form-item label="课程标题">
                <el-input v-model="courseInfo.title" placeholder=" 示例:机器学习项目课:从基础到搭建项目视频课程。专业名称注意大小写"/>
            </el-form-item>
    
            <!-- 所属分类 TODO -->
            <el-form-item label="课程分类">
                <el-select
                    v-model="courseInfo.subjectParentId"
                    placeholder="一级分类" @change="subjectLevelOneChanged">
    
                    <el-option
                        v-for="subject in subjectOneList"
                        :key="subject.id"
                        :label="subject.title"
                        :value="subject.id"/>
    
                </el-select>
    
                <!-- 二级分类 -->
                <el-select v-model="courseInfo.subjectId" placeholder="二级分类">
                    <el-option
                        v-for="subject in subjectTwoList"
                        :key="subject.id"
                        :label="subject.title"
                        :value="subject.id"/>
                </el-select>
            </el-form-item>
    
    
            <!-- 课程讲师 TODO -->
            <!-- 课程讲师 -->
            <el-form-item label="课程讲师">
            <el-select
                v-model="courseInfo.teacherId"
                placeholder="请选择">
    
                <el-option
                    v-for="teacher in teacherList"
                    :key="teacher.id"
                    :label="teacher.name"
                    :value="teacher.id"/>
    
            </el-select>
            </el-form-item>
    
            <el-form-item label="总课时">
                <el-input-number :min="0" v-model="courseInfo.lessonNum" controls-position="right" placeholder="请填写课程的总课时数"/>
            </el-form-item>
    
            <!-- 课程简介 TODO -->
            <el-form-item label="课程简介">
                <el-input v-model="courseInfo.description" placeholder=" "/>
            </el-form-item>
    
            <!-- 课程封面 TODO -->
            <!-- 课程封面-->
            <el-form-item label="课程封面">
    
                <el-upload
                    :show-file-list="false"
                    :on-success="handleAvatarSuccess"
                    :before-upload="beforeAvatarUpload"
                    :action="BASE_API+'/eduoss/file/upload'"
                    class="avatar-uploader">
                    <img :src="courseInfo.cover">
                </el-upload>
    
            </el-form-item>
    
            <el-form-item label="课程价格">
                <el-input-number :min="0" v-model="courseInfo.price" controls-position="right" placeholder="免费课程请设置为0元"/></el-form-item>
    
            <el-form-item>
                <el-button :disabled="saveBtnDisabled" type="primary" @click="saveOrUpdate">保存并下一步</el-button>
            </el-form-item>
            </el-form>
      </div>
    </template>
    <script>
    import course from '@/api/course/course'
    import subject from '@/api/subject/subject'
    export default {
        data() {
            return {
                saveBtnDisabled:false,
                courseInfo:{
                    title: '',
                    subjectId: '',//二级分类id
                    subjectParentId:'',//一级分类id
                    teacherId: '',
                    lessonNum: 0,
                    description: '',
                    cover: '/static/02.jpg',
                    price: 0
                },
                BASE_API: process.env.BASE_API, // 接口API地址
                teacherList:[],//封装所有的讲师
                subjectOneList:[],//一级分类
                subjectTwoList:[]//二级分类
            }   
        },
        created() {
            //初始化所有讲师
            this.getListTeacher()
            //初始化一级分类
            this.getOneSubject()
        },
        methods:{
            //上传封面成功调用的方法
            handleAvatarSuccess(res, file) {
                this.courseInfo.cover = res.data.url
            },
            //上传之前调用的方法
            beforeAvatarUpload(file) {
                const isJPG = file.type === 'image/jpeg'
                const isLt2M = file.size / 1024 / 1024 < 2
    
                if (!isJPG) {
                    this.$message.error('上传头像图片只能是 JPG 格式!')
                }
                if (!isLt2M) {
                    this.$message.error('上传头像图片大小不能超过 2MB!')
                }
                return isJPG && isLt2M
            },
            //点击某个一级分类,触发change,显示对应二级分类
            subjectLevelOneChanged(value) {
                //value就是一级分类id值
                //遍历所有的分类,包含一级和二级
                for(var i=0;i<this.subjectOneList.length;i++) {
                    //每个一级分类
                    var oneSubject = this.subjectOneList[i]
                    //判断:所有一级分类id 和 点击一级分类id是否一样
                    if(value === oneSubject.id) {
                        //从一级分类获取里面所有的二级分类
                        this.subjectTwoList = oneSubject.children
                        //把二级分类id值清空
                        this.courseInfo.subjectId = ''
                    }
                }
            },
            //查询所有的一级分类
            getOneSubject() {
                subject.getSubjectList()
                    .then(response => {
                        this.subjectOneList = response.data.items
                    })
            },
            //查询所有的讲师
            getListTeacher() {
                course.getListTeacher()
                    .then(response => {
                        this.teacherList = response.data.items
                    })
            },
            saveOrUpdate() {
                course.addCourseInfo(this.courseInfo)
                    .then(response => {
                        //提示
                        this.$message({
                            type: 'success',
                            message: '添加课程信息成功!'
                        });
                        //跳转到第二步
                        this.$router.push({path:'/course/chapter/'+response.data.courseid})
                    })
            }
        }
    }
    </script>
  • 相关阅读:
    IntelliJ Idea 常用快捷键列表
    管理Django1.9静态文件static
    django模板中如何导入js、css等外部文件
    Struts2+hibernate 结合,实现登陆校验
    python统计文档中词频
    Hibernate连接各种数据库的配置
    hibernateDAO层基本的增删改查
    vue2.0+element+node+webpack搭建的一个简单的后台管理界面
    WEB 前端开发插件整理
    机器学习之条件随机场(八)
  • 原文地址:https://www.cnblogs.com/dmzna/p/12818734.html
Copyright © 2020-2023  润新知