professionalIntroduction.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122
  1. <template>
  2. <view class="professional">
  3. <!-- 导航栏 -->
  4. <u-navbar title="" :background="background" title-color="#fff" back-icon-color="#fff" :border-bottom="false"/>
  5. <view class="professional-bg"></view>
  6. <view class="professional-content">
  7. <!-- 专业详情 -->
  8. <view class="professional-content-info">
  9. <view class="professional-content-info-left">
  10. <u-image :src="details.img" width="198" height="220" border-radius="10"/>
  11. </view>
  12. <view class="professional-content-info-right">
  13. <view class="name">
  14. <view>专业</view>
  15. <view>{{ details.name }}</view>
  16. <!-- <view>(630601)</view> -->
  17. </view>
  18. <view class="study">
  19. 难度 <u-rate :count="5" v-model="details.difficult" active-color="#EF651F" disabled size="30" :gutter="4"/>
  20. </view>
  21. <view class="study">
  22. 学习时间:{{ details.cycle }}年
  23. </view>
  24. </view>
  25. </view>
  26. <!-- 课程预览 -->
  27. <view class="professional-content-preview">
  28. <view class="professional-content-preview-video">
  29. <view class="title">
  30. <view><text>课程预览</text>精彩教学视频</view>
  31. <view @click="jumpPage('/pages/upgrade/upgradeCourse/upgradeCourse', { id: learnpackageId })">
  32. 更多<u-icon name="arrow-right"></u-icon>
  33. </view>
  34. </view>
  35. <view class="list" v-if="details.courseList && details.courseList.length">
  36. <swiper
  37. class="swiper"
  38. :indicator-dots="false"
  39. :autoplay="false"
  40. height="196rpx"
  41. >
  42. <swiper-item class="swiper-item" v-for="(item, index) in details.courseList" :key="index" @click="jumpPage('/pages/upgrade/courseDetail/courseDetail', { id: item.id })">
  43. <view class="image">
  44. <u-image :src="item.img" width="95%" height="196" border-radius="10"/>
  45. </view>
  46. <view class="classes-name">{{ item.name }}</view>
  47. <view class="classes-teacher">讲师:{{ item.teacherName }}</view>
  48. </swiper-item>
  49. </swiper>
  50. </view>
  51. <u-empty v-else text="暂无课程" mode="list" margin-top="50"></u-empty>
  52. </view>
  53. <!-- 专业介绍 -->
  54. <view class="professional-content-preview-introduction">
  55. <view class="title">
  56. <view><text>专业介绍</text>深入了解本课程</view>
  57. </view>
  58. <view class="content">
  59. <u-parse :html="details.description"></u-parse>
  60. </view>
  61. </view>
  62. </view>
  63. </view>
  64. </view>
  65. </template>
  66. <script>
  67. export default {
  68. data() {
  69. return {
  70. background: {
  71. backgroundColor: '#3D5D4C'
  72. },
  73. learnpackageId: '',
  74. details: {}
  75. }
  76. },
  77. onLoad(page) {
  78. if (page.id) {
  79. this.learnpackageId = page.id
  80. }
  81. },
  82. onShow() {
  83. if (this.learnpackageId) {
  84. this.getDetails(this.learnpackageId)
  85. }
  86. },
  87. methods: {
  88. /**
  89. * 获取专业详情
  90. * @param {Object} id
  91. */
  92. getDetails(id) {
  93. this.$u.api.school.getLearnpackageDetails({ id }).then(res => {
  94. console.log(res)
  95. if (res.code === 200) {
  96. this.details = res.data
  97. }
  98. })
  99. },
  100. /**
  101. * 跳转到指定页面
  102. * @param {Object} url
  103. * @param {Object} params
  104. */
  105. jumpPage(url, params) {
  106. this.$u.route({
  107. url,
  108. params
  109. })
  110. }
  111. }
  112. }
  113. </script>
  114. <style lang="scss" scoped>
  115. @import './professionalIntroduction.scss';
  116. </style>