diff --git a/vueHomilyLink/src/views/HomeView.vue b/vueHomilyLink/src/views/HomeView.vue index 9a7791b..89a0c11 100644 --- a/vueHomilyLink/src/views/HomeView.vue +++ b/vueHomilyLink/src/views/HomeView.vue @@ -3,16 +3,6 @@ import Nav from '@/components/Nav.vue'; import { ref, onMounted, reactive,computed } from 'vue'; import homeApi from '@/api/HomeApi'; -const articleImgSrc = ref(''); -const title = ref(''); -const authorAvatarSrc = ref(''); -const authorName = ref(''); -const viewsCount = ref(''); -const commentsCount = ref(''); -const likesCount = ref(''); -const playTime = ref(''); -const club_id=ref(''); - const seeSrc = ref(''); const pingSrc = ref(''); const zanSrc = ref(''); @@ -37,22 +27,29 @@ const articleData = reactive({ flag_type:'' }); -console.log('初始化后的articleData:', articleData); - // 定义一个函数,用于将接口返回的数据映射到articleData响应式对象中 const mapResponseToArticleData = (responseData) => { if (Array.isArray(responseData)) { + console.log('res:', responseData); articleData.articleImgSrc = responseData.map(item => item.cover); articleData.title = responseData.map(item => item.name); - articleData.authorAvatarSrc = responseData.map(item => item.avatar); - articleData.authorName = responseData.map(item => item.username); - articleData.viewsCount = responseData.map(item => item.view_count); + articleData.authorAvatarSrc = responseData.map(item => item.user.avatar); + articleData.authorName = responseData.map(item => item.user.username); + articleData.viewsCount = responseData.map(item => item.viewCount); articleData.commentsCount = responseData.map(item => item.comments); articleData.likesCount = responseData.map(item => item.likes); - articleData.playTime = responseData.map(item => item.video_duration); - articleData.publishTime = responseData.map(item => item.releaseTime); - articleData.club_id = responseData.map(item => item.club_id); - articleData.flag_type = responseData.map(item => item.flag_type); + articleData.playTime = responseData.map(item => item.videoDuration); + articleData.publishTime = responseData.map(item => { + const date = new Date(item.releaseTime); + const month = ('0' + (date.getMonth() + 1)).slice(-2); + const day = ('0' + date.getDate()).slice(-2); + const hours = ('0' + date.getHours()).slice(-2); + const minutes = ('0' + date.getMinutes()).slice(-2); + return `${month}-${day} ${hours}:${minutes}`; + }); + articleData.club_id = responseData.map(item => item.clubId); + articleData.flag_type = responseData.map(item => item.flagType); + } else { console.warn('接口返回的数据格式不符合预期'); } @@ -62,15 +59,43 @@ const mapResponseToArticleData = (responseData) => { async function selectAll() { try { const response = await homeApi.gethomeList(); - mapResponseToArticleData(response); + mapResponseToArticleData(response.data); + } catch (error) { console.error('获取数据出错:', error); } } - +console.log('初始化后的articleData:', articleData); selectAll(); + +// 精选视频接口 +const articleData2 = ref([]); +function fetchData (){ + homeApi.getHomeVideo().then(response => { + // 将articleData响应式对象赋值给articleData2 + articleData2.value = response.data; + articleData2.value = articleData2.value.map(item => { + const date = new Date(item.releaseTime); + const month = ('0' + (date.getMonth() + 1)).slice(-2); + const day = ('0' + date.getDate()).slice(-2); + const hours = ('0' + date.getHours()).slice(-2); + const minutes = ('0' + date.getMinutes()).slice(-2); + return { + ...item, + releaseTime: `${month}-${day} ${hours}:${minutes}` + }; + }); + console.log('初始化后的articleData2:', articleData2.value); + }).catch(error => { + console.error('获取数据出错:', error); + }); +}; +fetchData (); + + + const getColorClass = (index) => { const num = index + 1; if (num === 1) { @@ -83,9 +108,9 @@ const getColorClass = (index) => { return ''; }; -const filteredArticleData = computed(() => { - return articleData.title.filter((_, index) => articleData.flag_type[index] === 1); -}); +// const filteredArticleData = computed(() => { +// return articleData.title.filter((_, index) => articleData.flag_type[index] === 1); +// });