• vue框架前后端分离项目之课程接口、页面、前台等相关内容-127


    1 课程接口

    1 课程表设计(关联关系是字段和字段的关系,而不是表和表的关系)
    -课程分类表:跟课程一对多(一个课程分类下很多课程)
    -实战课表(一个课程有很多章节)
       -课程章节表(一个章节,有很多课时)
       -课时表
       -老师表(一个老师,讲很多课程)
       
       
       
    2 课程接口:
    -根据切图分析出需要返回的字段
       -带过滤功能:按分类过滤,按价格,人气升序降序
       -分页
       
       

     

    2 课程页面

    <template>
       <div class="course">
           <Header></Header>
           <div class="main">
               <!-- 筛选条件 -->
               <div class="condition">
                   <ul class="cate-list">
                       <li class="title">课程分类:</li>
                       <li :class="filter.course_category==0?'this':''" @click="filter.course_category=0">全部</li>
                       <li :class="filter.course_category==category.id?'this':''" v-for="category in category_list"
                           @click="filter.course_category=category.id" :key="category.name">{{category.name}}
                       </li>
                   </ul>

                   <div class="ordering">
                       <ul>
                           <li class="title">&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;选:</li>
                           <li class="default" :class="(filter.ordering=='id' || filter.ordering=='-id')?'this':''"
                               @click="filter.ordering='-id'">默认
                           </li>
                           <li class="hot" :class="(filter.ordering=='students' || filter.ordering=='-students')?'this':''"
                               @click="filter.ordering=(filter.ordering=='-students'?'students':'-students')">人气
                           </li>
                           <li class="price"
                              :class="filter.ordering=='price'?'price_up this':(filter.ordering=='-price'?'price_down this':'')"
                               @click="filter.ordering=(filter.ordering=='-price'?'price':'-price')">价格
                           </li>
                       </ul>
                       <p class="condition-result">共{{course_total}}个课程</p>
                   </div>

               </div>
               <!-- 课程列表 -->
               <div class="course-list">
                   <div class="course-item" v-for="course in course_list" :key="course.name">
                       <div class="course-image">
                           <img :src="course.course_img" alt="">
                       </div>
                       <div class="course-info">
                           <h3>
                               <router-link :to="'/course/detail/'+course.id">{{course.name}}</router-link>
                               <span><img src="@/assets/img/avatar1.svg" alt="">{{course.students}}人已加入学习</span></h3>
                           <p class="teather-info">
                              {{course.teacher.name}} {{course.teacher.title}} {{course.teacher.signature}}
                               <span v-if="course.sections>course.pub_sections">共{{course.sections}}课时/已更新{{course.pub_sections}}课时</span>
                               <span v-else>共{{course.sections}}课时/更新完成</span>
                           </p>
                           <ul class="section-list">
                               <li v-for="(section, key) in course.section_list" :key="section.name"><span
                                       class="section-title">0{{key+1}}  | {{section.name}}</span>
                                   <span class="free" v-if="section.free_trail">免费</span></li>
                           </ul>
                           <div class="pay-box">
                               <div v-if="course.discount_type">
                                   <span class="discount-type">{{course.discount_type}}</span>
                                   <span class="discount-price">¥{{course.real_price}}</span>
                                   <span class="original-price">原价:{{course.price}}</span>
                               </div>
                               <span v-else class="discount-price">¥{{course.price}}</span>
                               <span class="buy-now">立即购买</span>
                           </div>
                       </div>
                   </div>
               </div>
               <div class="course_pagination block">
                   <el-pagination
                           @size-change="handleSizeChange"
                           @current-change="handleCurrentChange"
                          :current-page.sync="filter.page"
                          :page-sizes="[2, 3, 5, 10]"
                          :page-size="filter.page_size"
                           layout="sizes, prev, pager, next"
                          :total="course_total">
                   </el-pagination>
               </div>
           </div>
           <Footer></Footer>
       </div>
    </template>

    <script>
       import Header from "@/components/Header"
       import Footer from "@/components/Footer"

       export default {
           name: "Course",
           data() {
               return {
                   category_list: [], // 课程分类列表
                   course_list: [],   // 课程列表
                   course_total: 0,   // 当前课程的总数量
                   filter: {
                       course_category: 0, // 当前用户选择的课程分类,刚进入页面默认为全部,值为0
                       ordering: "-id",    // 数据的排序方式,默认值是-id,表示对于id进行降序排列
                       page_size: 2,       // 单页数据量
                       page: 1,
                  }
              }
          },
           created() {
               this.get_category();
               this.get_course();
          },
           components: {
               Header,
               Footer,
          },
           watch: {
               "filter.course_category": function () {
                   this.filter.page = 1;
                   this.get_course();
              },
               "filter.ordering": function () {
                   this.get_course();
              },
               "filter.page_size": function () {
                   this.get_course();
              },
               "filter.page": function () {
                   this.get_course();
              }
          },
           methods: {

               handleSizeChange(val) {
                   // 每页数据量发生变化时执行的方法
                   this.filter.page = 1;
                   this.filter.page_size = val;
              },
               handleCurrentChange(val) {
                   // 页码发生变化时执行的方法
                   this.filter.page = val;
              },
               get_category() {
                   // 获取课程分类信息
                   this.$axios.get(`${this.$settings.base_url}/course/category/`).then(response => {
                       this.category_list = response.data;
                  }).catch(() => {
                       this.$message({
                           message: "获取课程分类信息有误,请联系客服工作人员",
                      })
                  })
              },
               get_course() {
                   // 排序
                   let filters = {
                       ordering: this.filter.ordering, // 排序
                  };
                   // 判决是否进行分类课程的展示
                   if (this.filter.course_category > 0) {
                       filters.course_category = this.filter.course_category;
                  }

                   // 设置单页数据量
                   if (this.filter.page_size > 0) {
                       filters.page_size = this.filter.page_size;
                  } else {
                       filters.page_size = 5;
                  }

                   // 设置当前页码
                   if (this.filter.page > 1) {
                       filters.page = this.filter.page;
                  } else {
                       filters.page = 1;
                  }


                   // 获取课程列表信息
                   this.$axios.get(`${this.$settings.base_url}/course/free/`, {
                       params: filters
                  }).then(response => {
                       // console.log(response.data);
                       this.course_list = response.data.results;
                       this.course_total = response.data.count;
                       // console.log(this.course_list);
                  }).catch(() => {
                       this.$message({
                           message: "获取课程信息有误,请联系客服工作人员"
                      })
                  })
              }
          }
      }
    </script>

    <style scoped>
      .course {
           background: #f6f6f6;
      }

      .course .main {
            1100px;
           margin: 35px auto 0;
      }

      .course .condition {
           margin-bottom: 35px;
           padding: 25px 30px 25px 20px;
           background: #fff;
           border-radius: 4px;
           box-shadow: 0 2px 4px 0 #f0f0f0;
      }

      .course .cate-list {
           border-bottom: 1px solid #333;
           border-bottom-color: rgba(51, 51, 51, .05);
           padding-bottom: 18px;
           margin-bottom: 17px;
      }

      .course .cate-list::after {
           content: "";
           display: block;
           clear: both;
      }

      .course .cate-list li {
           float: left;
           font-size: 16px;
           padding: 6px 15px;
           line-height: 16px;
           margin-left: 14px;
           position: relative;
           transition: all .3s ease;
           cursor: pointer;
           color: #4a4a4a;
           border: 1px solid transparent; /* transparent 透明 */
      }

      .course .cate-list .title {
           color: #888;
           margin-left: 0;
           letter-spacing: .36px;
           padding: 0;
           line-height: 28px;
      }

      .course .cate-list .this {
           color: #ffc210;
           border: 1px solid #ffc210 !important;
           border-radius: 30px;
      }

      .course .ordering::after {
           content: "";
           display: block;
           clear: both;
      }

      .course .ordering ul {
           float: left;
      }

      .course .ordering ul::after {
           content: "";
           display: block;
           clear: both;
      }

      .course .ordering .condition-result {
           float: right;
           font-size: 14px;
           color: #9b9b9b;
           line-height: 28px;
      }

      .course .ordering ul li {
           float: left;
           padding: 6px 15px;
           line-height: 16px;
           margin-left: 14px;
           position: relative;
           transition: all .3s ease;
           cursor: pointer;
           color: #4a4a4a;
      }

      .course .ordering .title {
           font-size: 16px;
           color: #888;
           letter-spacing: .36px;
           margin-left: 0;
           padding: 0;
           line-height: 28px;
      }

      .course .ordering .this {
           color: #ffc210;
      }

      .course .ordering .price {
           position: relative;
      }

      .course .ordering .price::before,
      .course .ordering .price::after {
           cursor: pointer;
           content: "";
           display: block;
            0px;
           height: 0px;
           border: 5px solid transparent;
           position: absolute;
           right: 0;
      }

      .course .ordering .price::before {
           border-bottom: 5px solid #aaa;
           margin-bottom: 2px;
           top: 2px;
      }

      .course .ordering .price::after {
           border-top: 5px solid #aaa;
           bottom: 2px;
      }

      .course .ordering .price_up::before {
           border-bottom-color: #ffc210;
      }

      .course .ordering .price_down::after {
           border-top-color: #ffc210;
      }

      .course .course-item:hover {
           box-shadow: 4px 6px 16px rgba(0, 0, 0, .5);
      }

      .course .course-item {
            1100px;
           background: #fff;
           padding: 20px 30px 20px 20px;
           margin-bottom: 35px;
           border-radius: 2px;
           cursor: pointer;
           box-shadow: 2px 3px 16px rgba(0, 0, 0, .1);
           /* css3.0 过渡动画 hover 事件操作 */
           transition: all .2s ease;
      }

      .course .course-item::after {
           content: "";
           display: block;
           clear: both;
      }

       /* 顶级元素 父级元素  当前元素{} */
      .course .course-item .course-image {
           float: left;
            423px;
           height: 210px;
           margin-right: 30px;
      }

      .course .course-item .course-image img {
           max- 100%;
           max-height: 210px;
      }

      .course .course-item .course-info {
           float: left;
            596px;
      }

      .course-item .course-info h3 a {
           font-size: 26px;
           color: #333;
           font-weight: normal;
           margin-bottom: 8px;
      }

      .course-item .course-info h3 span {
           font-size: 14px;
           color: #9b9b9b;
           float: right;
           margin-top: 14px;
      }

      .course-item .course-info h3 span img {
            11px;
           height: auto;
           margin-right: 7px;
      }

      .course-item .course-info .teather-info {
           font-size: 14px;
           color: #9b9b9b;
           margin-bottom: 14px;
           padding-bottom: 14px;
           border-bottom: 1px solid #333;
           border-bottom-color: rgba(51, 51, 51, .05);
      }

      .course-item .course-info .teather-info span {
           float: right;
      }

      .course-item .section-list::after {
           content: "";
           display: block;
           clear: both;
      }

      .course-item .section-list li {
           float: left;
            44%;
           font-size: 14px;
           color: #666;
           padding-left: 22px;
           /* background: url("路径") 是否平铺 x轴位置 y轴位置 */
           background: url("/src/assets/img/play-icon-gray.svg") no-repeat left 4px;
           margin-bottom: 15px;
      }

      .course-item .section-list li .section-title {
           /* 以下3句,文本内容过多,会自动隐藏,并显示省略符号 */
           text-overflow: ellipsis;
           overflow: hidden;
           white-space: nowrap;
           display: inline-block;
           max- 200px;
      }

      .course-item .section-list li:hover {
           background-image: url("/src/assets/img/play-icon-yellow.svg");
           color: #ffc210;
      }

      .course-item .section-list li .free {
            34px;
           height: 20px;
           color: #fd7b4d;
           vertical-align: super;
           margin-left: 10px;
           border: 1px solid #fd7b4d;
           border-radius: 2px;
           text-align: center;
           font-size: 13px;
           white-space: nowrap;
      }

      .course-item .section-list li:hover .free {
           color: #ffc210;
           border-color: #ffc210;
      }

      .course-item {
           position: relative;
      }

      .course-item .pay-box {
           position: absolute;
           bottom: 20px;
            600px;
      }

      .course-item .pay-box::after {
           content: "";
           display: block;
           clear: both;
      }

      .course-item .pay-box .discount-type {
           padding: 6px 10px;
           font-size: 16px;
           color: #fff;
           text-align: center;
           margin-right: 8px;
           background: #fa6240;
           border: 1px solid #fa6240;
           border-radius: 10px 0 10px 0;
           float: left;
      }

      .course-item .pay-box .discount-price {
           font-size: 24px;
           color: #fa6240;
           float: left;
      }

      .course-item .pay-box .original-price {
           text-decoration: line-through;
           font-size: 14px;
           color: #9b9b9b;
           margin-left: 10px;
           float: left;
           margin-top: 10px;
      }

      .course-item .pay-box .buy-now {
            120px;
           height: 38px;
           background: transparent;
           color: #fa6240;
           font-size: 16px;
           border: 1px solid #fd7b4d;
           border-radius: 3px;
           transition: all .2s ease-in-out;
           float: right;
           text-align: center;
           line-height: 38px;
           position: absolute;
           right: 0;
           bottom: 5px;
      }

      .course-item .pay-box .buy-now:hover {
           color: #fff;
           background: #ffc210;
           border: 1px solid #ffc210;
      }

      .course .course_pagination {
           margin-bottom: 60px;
           text-align: center;
      }
    </style>

     

    3 课程详情前台

    <template>
       <div class="detail">
           <Header/>
           <div class="main">
               <div class="course-info">
                   <div class="wrap-left">

                       <videoPlayer class="video-player vjs-custom-skin"
                                    ref="videoPlayer"
                                    :playsinline="true"
                                    :options="playerOptions"
                                    @play="onPlayerPlay($event)"
                                    @pause="onPlayerPause($event)">
                       </videoPlayer>
                   </div>
                   <div class="wrap-right">
                       <h3 class="course-name">{{course_info.name}}</h3>
                       <p class="data">{{course_info.students}}人在学&nbsp;&nbsp;&nbsp;&nbsp;课程总时长:{{course_info.sections}}课时/{{course_info.pub_sections}}小时&nbsp;&nbsp;&nbsp;&nbsp;难度:{{course_info.level_name}}</p>
                       <div class="sale-time">
                           <p class="sale-type">价格 <span class="original_price">¥{{course_info.price}}</span></p>
                           <p class="expire"></p>
                       </div>
                       <div class="buy">
                           <div class="buy-btn">
                               <button class="buy-now">立即购买</button>
                               <button class="free">免费试学</button>
                           </div>
                           <!--<div class="add-cart" @click="add_cart(course_info.id)">-->
    <!--<img src="@/assets/img/cart-yellow.svg" alt="">加入购物车-->
                           <!--</div>-->
                       </div>
                   </div>
               </div>
               <div class="course-tab">
                   <ul class="tab-list">
                       <li :class="tabIndex==1?'active':''" @click="tabIndex=1">详情介绍</li>
                       <li :class="tabIndex==2?'active':''" @click="tabIndex=2">课程章节 <span :class="tabIndex!=2?'free':''">(试学)</span>
                       </li>
                       <li :class="tabIndex==3?'active':''" @click="tabIndex=3">用户评论</li>
                       <li :class="tabIndex==4?'active':''" @click="tabIndex=4">常见问题</li>
                   </ul>
               </div>
               <div class="course-content">
                   <div class="course-tab-list">
                       <div class="tab-item" v-if="tabIndex==1">
                           <div class="course-brief" v-html="course_info.brief_text"></div>
                       </div>
                       <div class="tab-item" v-if="tabIndex==2">
                           <div class="tab-item-title">
                               <p class="chapter">课程章节</p>
                               <p class="chapter-length">共{{course_chapters.length}}章 {{course_info.sections}}个课时</p>
                           </div>
                           <div class="chapter-item" v-for="chapter in course_chapters" :key="chapter.name">
                               <p class="chapter-title"><img src="@/assets/img/enum.svg" alt="">第{{chapter.chapter}}章·{{chapter.name}}
                               </p>
                               <ul class="section-list">
                                   <li class="section-item" v-for="section in chapter.coursesections" :key="section.name">
                                       <p class="name"><span class="index">{{chapter.chapter}}-{{section.orders}}</span>
                                          {{section.name}}<span class="free" v-if="section.free_trail">免费</span></p>
                                       <p class="time">{{section.duration}} <img src="@/assets/img/chapter-player.svg"></p>
                                       <button class="try" v-if="section.free_trail">立即试学</button>
                                       <button class="try" v-else>立即购买</button>
                                   </li>
                               </ul>
                           </div>
                       </div>
                       <div class="tab-item" v-if="tabIndex==3">
                           用户评论
                       </div>
                       <div class="tab-item" v-if="tabIndex==4">
                           常见问题
                       </div>
                   </div>
                   <div class="course-side">
                       <div class="teacher-info">
                           <h4 class="side-title"><span>授课老师</span></h4>
                           <div class="teacher-content">
                               <div class="cont1">
                                   <img :src="course_info.teacher.image">
                                   <div class="name">
                                       <p class="teacher-name">{{course_info.teacher.name}}
                                          {{course_info.teacher.title}}</p>
                                       <p class="teacher-title">{{course_info.teacher.signature}}</p>
                                   </div>
                               </div>
                               <p class="narrative">{{course_info.teacher.brief}}</p>
                           </div>
                       </div>
                   </div>
               </div>
           </div>
           <Footer/>
       </div>
    </template>

    <script>
       import Header from "@/components/Header"
       import Footer from "@/components/Footer"

       // 加载组件
       import {videoPlayer} from 'vue-video-player';

       export default {
           name: "Detail",
           data() {
               return {
                   tabIndex: 2,   // 当前选项卡显示的下标
                   course_id: 0, // 当前课程信息的ID
                   course_info: {
                       teacher: {},
                  }, // 课程信息
                   course_chapters: [], // 课程的章节课时列表
                   playerOptions: {
                       playbackRates: [0.5, 1.0, 1.5, 2.0],
                       aspectRatio: '16:9', // 将播放器置于流畅模式,并在计算播放器的动态大小时使用该值。值应该代表一个比例 - 用冒号分隔的两个数字(例如"16:9""4:3"

                       sources: [{ // 播放资源和资源格式
                           type: "video/mp4",
                           src: "http://img.ksbbs.com/asset/Mon_1703/05cacb4e02f9d9e.mp4" //你的视频地址(必填)
                      }],
                  }
              }
          },
           created() {
               this.get_course_id();
               this.get_course_data();
               this.get_chapter();
          },
           methods: {
               onPlayerPlay() {
                   // 当视频播放时,执行的方法
                   console.log('视频开始播放')
              },
               onPlayerPause() {
                   // 当视频暂停播放时,执行的方法
                   console.log('视频暂停,可以打开广告了')
              },
               get_course_id() {
                   // 获取地址栏上面的课程ID
                   this.course_id = this.$route.params.pk || this.$route.query.pk;
                   if (this.course_id < 1) {
                       let _this = this;
                       _this.$alert("对不起,当前视频不存在!", "警告", {
                           callback() {
                               _this.$router.go(-1);
                          }
                      });
                  }
              },
               get_course_data() {
                   // ajax请求课程信息
                   this.$axios.get(`${this.$settings.base_url}/course/free/${this.course_id}/`).then(response => {
                       // window.console.log(response.data);
                       this.course_info = response.data;
                       console.log(this.course_info)
                  }).catch(() => {
                       this.$message({
                           message: "对不起,访问页面出错!请联系客服工作人员!"
                      });
                  })
              },

               get_chapter() {
                   // 获取当前课程对应的章节课时信息
                   // http://127.0.0.1:8000/course/chapters/?course=(pk)
                   this.$axios.get(`${this.$settings.base_url}/course/chapters/`, {
                       params: {
                           "course": this.course_id,
                      }
                  }).then(response => {
                       this.course_chapters = response.data;
                  }).catch(error => {
                       window.console.log(error.response);
                  })
              },
          },
           components: {
               Header,
               Footer,
               videoPlayer, // 注册组件
          }
      }
    </script>

    <style scoped>
      .main {
           background: #fff;
           padding-top: 30px;
      }

      .course-info {
            1200px;
           margin: 0 auto;
           overflow: hidden;
      }

      .wrap-left {
           float: left;
            690px;
           height: 388px;
           background-color: #000;
      }

      .wrap-right {
           float: left;
           position: relative;
           height: 388px;
      }

      .course-name {
           font-size: 20px;
           color: #333;
           padding: 10px 23px;
           letter-spacing: .45px;
      }

      .data {
           padding-left: 23px;
           padding-right: 23px;
           padding-bottom: 16px;
           font-size: 14px;
           color: #9b9b9b;
      }

      .sale-time {
            464px;
           background: #fa6240;
           font-size: 14px;
           color: #4a4a4a;
           padding: 10px 23px;
           overflow: hidden;
      }

      .sale-type {
           font-size: 16px;
           color: #fff;
           letter-spacing: .36px;
           float: left;
      }

      .sale-time .expire {
           font-size: 14px;
           color: #fff;
           float: right;
      }

      .sale-time .expire .second {
            24px;
           display: inline-block;
           background: #fafafa;
           color: #5e5e5e;
           padding: 6px 0;
           text-align: center;
      }

      .course-price {
           background: #fff;
           font-size: 14px;
           color: #4a4a4a;
           padding: 5px 23px;
      }

      .discount {
           font-size: 26px;
           color: #fa6240;
           margin-left: 10px;
           display: inline-block;
           margin-bottom: -5px;
      }

      .original {
           font-size: 14px;
           color: #9b9b9b;
           margin-left: 10px;
           text-decoration: line-through;
      }

      .buy {
            464px;
           padding: 0px 23px;
           position: absolute;
           left: 0;
           bottom: 20px;
           overflow: hidden;
      }

      .buy .buy-btn {
           float: left;
      }

      .buy .buy-now {
            125px;
           height: 40px;
           border: 0;
           background: #ffc210;
           border-radius: 4px;
           color: #fff;
           cursor: pointer;
           margin-right: 15px;
           outline: none;
      }

      .buy .free {
            125px;
           height: 40px;
           border-radius: 4px;
           cursor: pointer;
           margin-right: 15px;
           background: #fff;
           color: #ffc210;
           border: 1px solid #ffc210;
      }

      .add-cart {
           float: right;
           font-size: 14px;
           color: #ffc210;
           text-align: center;
           cursor: pointer;
           margin-top: 10px;
      }

      .add-cart img {
            20px;
           height: 18px;
           margin-right: 7px;
           vertical-align: middle;
      }

      .course-tab {
            100%;
           background: #fff;
           margin-bottom: 30px;
           box-shadow: 0 2px 4px 0 #f0f0f0;

      }

      .course-tab .tab-list {
            1200px;
           margin: auto;
           color: #4a4a4a;
           overflow: hidden;
      }

      .tab-list li {
           float: left;
           margin-right: 15px;
           padding: 26px 20px 16px;
           font-size: 17px;
           cursor: pointer;
      }

      .tab-list .active {
           color: #ffc210;
           border-bottom: 2px solid #ffc210;
      }

      .tab-list .free {
           color: #fb7c55;
      }

      .course-content {
            1200px;
           margin: 0 auto;
           background: #FAFAFA;
           overflow: hidden;
           padding-bottom: 40px;
      }

      .course-tab-list {
            880px;
           height: auto;
           padding: 20px;
           background: #fff;
           float: left;
           box-sizing: border-box;
           overflow: hidden;
           position: relative;
           box-shadow: 0 2px 4px 0 #f0f0f0;
      }

      .tab-item {
            880px;
           background: #fff;
           padding-bottom: 20px;
           box-shadow: 0 2px 4px 0 #f0f0f0;
      }

      .tab-item-title {
           justify-content: space-between;
           padding: 25px 20px 11px;
           border-radius: 4px;
           margin-bottom: 20px;
           border-bottom: 1px solid #333;
           border-bottom-color: rgba(51, 51, 51, .05);
           overflow: hidden;
      }

      .chapter {
           font-size: 17px;
           color: #4a4a4a;
           float: left;
      }

      .chapter-length {
           float: right;
           font-size: 14px;
           color: #9b9b9b;
           letter-spacing: .19px;
      }

      .chapter-title {
           font-size: 16px;
           color: #4a4a4a;
           letter-spacing: .26px;
           padding: 12px;
           background: #eee;
           border-radius: 2px;
           display: -ms-flexbox;
           display: flex;
           -ms-flex-align: center;
           align-items: center;
      }

      .chapter-title img {
            18px;
           height: 18px;
           margin-right: 7px;
           vertical-align: middle;
      }

      .section-list {
           padding: 0 20px;
      }

      .section-list .section-item {
           padding: 15px 20px 15px 36px;
           cursor: pointer;
           justify-content: space-between;
           position: relative;
           overflow: hidden;
      }

      .section-item .name {
           font-size: 14px;
           color: #666;
           float: left;
      }

      .section-item .index {
           margin-right: 5px;
      }

      .section-item .free {
           font-size: 12px;
           color: #fff;
           letter-spacing: .19px;
           background: #ffc210;
           border-radius: 100px;
           padding: 1px 9px;
           margin-left: 10px;
      }

      .section-item .time {
           font-size: 14px;
           color: #666;
           letter-spacing: .23px;
           opacity: 1;
           transition: all .15s ease-in-out;
           float: right;
      }

      .section-item .time img {
            18px;
           height: 18px;
           margin-left: 15px;
           vertical-align: text-bottom;
      }

      .section-item .try {
            86px;
           height: 28px;
           background: #ffc210;
           border-radius: 4px;
           font-size: 14px;
           color: #fff;
           position: absolute;
           right: 20px;
           top: 10px;
           opacity: 0;
           transition: all .2s ease-in-out;
           cursor: pointer;
           outline: none;
           border: none;
      }

      .section-item:hover {
           background: #fcf7ef;
           box-shadow: 0 0 0 0 #f3f3f3;
      }

      .section-item:hover .name {
           color: #333;
      }

      .section-item:hover .try {
           opacity: 1;
      }

      .course-side {
            300px;
           height: auto;
           margin-left: 20px;
           float: right;
      }

      .teacher-info {
           background: #fff;
           margin-bottom: 20px;
           box-shadow: 0 2px 4px 0 #f0f0f0;
      }

      .side-title {
           font-weight: normal;
           font-size: 17px;
           color: #4a4a4a;
           padding: 18px 14px;
           border-bottom: 1px solid #333;
           border-bottom-color: rgba(51, 51, 51, .05);
      }

      .side-title span {
           display: inline-block;
           border-left: 2px solid #ffc210;
           padding-left: 12px;
      }

      .teacher-content {
           padding: 30px 20px;
           box-sizing: border-box;
      }

      .teacher-content .cont1 {
           margin-bottom: 12px;
           overflow: hidden;
      }

      .teacher-content .cont1 img {
            54px;
           height: 54px;
           margin-right: 12px;
           float: left;
      }

      .teacher-content .cont1 .name {
           float: right;
      }

      .teacher-content .cont1 .teacher-name {
            188px;
           font-size: 16px;
           color: #4a4a4a;
           padding-bottom: 4px;
      }

      .teacher-content .cont1 .teacher-title {
            188px;
           font-size: 13px;
           color: #9b9b9b;
           white-space: nowrap;
      }

      .teacher-content .narrative {
           font-size: 14px;
           color: #666;
           line-height: 24px;
      }
    </style>

     

     

  • 相关阅读:
    【UML】基本介绍与类图(依赖、泛化、实现、关联、聚合、组合关系)
    【Java】集合综合案例
    【Java】集合框架(List Set Map)
    【Java】面向对象
    【Java】单例模式(Singleton)
    正则表达式(括号)、[中括号]、{大括号}的区别
    js正则表单验证汇总,邮箱验证,日期验证,电话号码验证,url验证,信用卡验证,qq验证
    网页倒计时,动态显示"××年还剩××天××时××分××秒"
    判断鼠标是否在指定区域代码
    鼠标左中右键返回值的兼容性问题
  • 原文地址:https://www.cnblogs.com/usherwang/p/14264424.html
Copyright © 2020-2023  润新知