|
|
@ -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); |
|
|
|
// }); |
|
|
|
</script> |
|
|
|
|
|
|
|
<template> |
|
|
@ -114,8 +139,8 @@ const filteredArticleData = computed(() => { |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<p>{{ title }}</p> |
|
|
|
<span class="articleinfo-avatar islink"> |
|
|
|
<p><b>{{ title }}</b></p> |
|
|
|
<span class="articleinfo-avatar islink" style="font-size: 14px;"> |
|
|
|
<img :src="articleData.authorAvatarSrc[index]" alt="作者头像"> |
|
|
|
{{ articleData.authorName[index] }} |
|
|
|
</span> |
|
|
@ -138,28 +163,31 @@ const filteredArticleData = computed(() => { |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
<!-- 精选视频 --> |
|
|
|
<div class="sidebar-right" style="width: 400px; float: right;"> |
|
|
|
<div> |
|
|
|
<img |
|
|
|
src="" |
|
|
|
alt style="width: 20px; height: 20px; margin-right: 5px; vertical-align: middle;">精选视频 |
|
|
|
</div> |
|
|
|
<ul class="data-list" > |
|
|
|
<li class="data-list-li articleList" v-for="(title, index) in filteredArticleData" :key="index"> |
|
|
|
<div class="articleimg" > |
|
|
|
<ul class="data-list" > |
|
|
|
<li class="data-list-li articleList" v-for="(article, index) in articleData2" :key="index"> |
|
|
|
<div class="articleimg"> |
|
|
|
<div class="el-image articleimg-img" > |
|
|
|
<img :src="articleData.articleImgSrc[index]" alt="文章图片"> |
|
|
|
<img :src="article.cover" alt="文章图片"> |
|
|
|
<span :class="['corner-mark', getColorClass(index)]">{{ index + 1 }}</span> |
|
|
|
<span class="play-time">{{ articleData.playTime[index] }}</span> |
|
|
|
<span class="play-time">{{ article.videoDuration }}</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<h5>{{ title }}</h5> |
|
|
|
<span class="homepage-list-li-see"> |
|
|
|
<span class="articletitle">{{ article.name }}</span> |
|
|
|
<span class="see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
{{ articleData.viewsCount[index] }} |
|
|
|
{{ article.viewCount }} |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time">{{ articleData.publishTime[index] }}</span> |
|
|
|
<span class="articleinfo-time">{{ article.releaseTime }}</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
@ -169,6 +197,11 @@ const filteredArticleData = computed(() => { |
|
|
|
</template> |
|
|
|
|
|
|
|
<style scoped> |
|
|
|
.articletitle{ |
|
|
|
display: block; |
|
|
|
font-size: 16px; |
|
|
|
margin-bottom: 20px; |
|
|
|
} |
|
|
|
.play-icon { |
|
|
|
width: 0; |
|
|
|
height: 0; |
|
|
@ -212,15 +245,18 @@ body { |
|
|
|
height: 100px; |
|
|
|
margin-right: 10px; /* 减少右边距以让文字更靠近图片 */ |
|
|
|
border-radius: 5px; |
|
|
|
overflow: hidden; |
|
|
|
/* overflow: hidden; */ |
|
|
|
} |
|
|
|
.articleimg-img img { |
|
|
|
width: 100%; |
|
|
|
width: 150px; |
|
|
|
height: 90px; |
|
|
|
object-fit: cover; |
|
|
|
} |
|
|
|
.articleinfo { |
|
|
|
flex-grow: 1; |
|
|
|
font-size: 20px; |
|
|
|
margin: 0; |
|
|
|
padding: 0; |
|
|
|
} |
|
|
|
.articleinfo p { |
|
|
|
margin: 0; /* 移除外边距 */ |
|
|
@ -242,8 +278,8 @@ body { |
|
|
|
border-radius: 50%; |
|
|
|
} |
|
|
|
.articleinfo-time { |
|
|
|
font-size: 16px; |
|
|
|
color: #999; |
|
|
|
font-size: 13px; |
|
|
|
color: #000000; |
|
|
|
margin-left: 10px; |
|
|
|
} |
|
|
|
.homepage-list-li-see, |
|
|
@ -252,12 +288,23 @@ body { |
|
|
|
display: inline-block; |
|
|
|
margin-left: 10px; |
|
|
|
cursor: pointer; |
|
|
|
font-size: 13px; |
|
|
|
} |
|
|
|
.homepage-list-li-see img, |
|
|
|
.homepage-list-li-ping img, |
|
|
|
.homepage-list-1i-zan img { |
|
|
|
width: 20px; |
|
|
|
height: 20px; |
|
|
|
padding: 0; |
|
|
|
margin-left: 0; |
|
|
|
} |
|
|
|
.see{ |
|
|
|
margin-left: 0; |
|
|
|
font-size: 13px; |
|
|
|
} |
|
|
|
.see img{ |
|
|
|
width: 20px; |
|
|
|
height: 20px; |
|
|
|
} |
|
|
|
.class123{ |
|
|
|
/*让页面分为左右结构*/ |
|
|
|