You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
zhishifufei_uniapp/pages/special/specialCateCourse.vue

141 lines
3.7 KiB

10 months ago
<template>
9 months ago
<BaseContainer class="course-container">
10 months ago
<view class="course-box">
<NavBar :title="specialCate" />
9 months ago
<template v-for="(item, index) in specialMenu">
<view v-if="specialData[item.key] && specialData[item.key].length > 0" :key="index" class="special-content">
10 months ago
<view class="special-content-title">
9 months ago
{{ item.menuName }}
10 months ago
</view>
8 months ago
<square-style-course v-if="item.menuName === '录播课程' || item.menuName === '热门课程'" :specialList="specialData[item.key]" @detail="handleSpecialClick"></square-style-course>
9 months ago
<offline-style-course v-if="item.menuName === '线下课堂'" :specialList="specialData[item.key]" @detail="handleSpecialClick"></offline-style-course>
9 months ago
<view class="showMore flex" @click="loadMore(item.key)">加载更多<text class="more"></text> </view>
10 months ago
</view>
</template>
</view>
</BaseContainer>
</template>
<script>
9 months ago
import { getSpecialCateData } from "@/api/special";
10 months ago
import LineStyleCourse from '@/components/Course/lineStyleCourse.vue';
import SquareStyleCourse from '@/components/Course/squareStyleCourse.vue';
import OfflineStyleCourse from '@/components/Course/offlineStyleCourse.vue';
export default {
components: {
LineStyleCourse,
SquareStyleCourse,
OfflineStyleCourse,
},
data() {
return {
9 months ago
specialCate: '',
9 months ago
gradeId: '',
subjectId: '',
9 months ago
specialMenu: [
8 months ago
{ menuName: '录播课程', key: 'video_list' },
9 months ago
{ menuName: '热门课程', key: 'hot_course' },
{ menuName: '线下课堂', key: 'offline_courses' },
10 months ago
],
9 months ago
specialData: [],
10 months ago
};
},
onLoad(options) {
this.specialCate = options.name;
9 months ago
this.gradeId = options.gradeId;
this.subjectId = options.subjectId;
9 months ago
this.getSpecialCateData();
10 months ago
},
methods: {
9 months ago
loadMore(key) {
9 months ago
if (key === 'offline_courses') {
uni.navigateTo({
url: `/pages/activity/activity_list?gradeId=${this.gradeId}&subjectId=${this.subjectId}`
});
9 months ago
} else {
uni.navigateTo({
url: `/pages/special/search?gradeId=${this.gradeId}&subjectId=${this.subjectId}&specialCate=0`
9 months ago
})
}
10 months ago
},
handleSpecialClick(item) {
const url = item.is_light
? '/pages/special/single_details?id=' + item.id
: '/pages/special/details?id=' + item.id;
// this.$util.checkLogin(() => {
uni.navigateTo({
url,
});
// }, this.showLoginPage);
},
9 months ago
async getSpecialCateData() {
try {
const { data, code, msg } = await getSpecialCateData({
9 months ago
grade_id: this.gradeId,
subject_id: this.subjectId,
9 months ago
});
this.loading = false;
if (code != 200) {
uni.showToast({
title: msg,
});
} else {
console.log(data, 646);
this.specialData = { ...data };
this.specialMenu.forEach(v => {
console.log(this.specialData, this.specialData[v.key]);
})
}
} catch (err) {
this.loading = false;
console.log(err);
}
},
10 months ago
},
};
</script>
<style lang="scss" scoped>
9 months ago
.course-container {
background: #f4f4f4;
}
10 months ago
.course-box {
padding-bottom: 40rpx;
}
.special-content {
padding: 40rpx 30rpx 0;
.special-content-title {
padding-left: 23rpx;
position: relative;
color: #333;
font-size: 34rpx;
line-height: 34rpx;
margin-bottom: 33rpx;
&:before {
content: '';
background: linear-gradient(0deg, #24a9e1, #0f74bb);
position: absolute;
top: 50%;
left: 0;
transform: translateY(-50%);
width: 8rpx;
height: 26rpx;
border-radius: 4rpx;
}
}
.showMore {
justify-content: center;
color: #666;
font-size: 24rpx;
line-height: 24rpx;
margin-top: 30rpx;
text {
9 months ago
transform: rotate(135deg);
10 months ago
margin-left: 15rpx;
}
}
}
</style>