|
|
@ -1,7 +1,7 @@ |
|
|
|
<script setup> |
|
|
|
import Nav from '@/components/Nav.vue'; |
|
|
|
import { ref, onMounted, reactive } from 'vue'; |
|
|
|
import axios from 'axios'; |
|
|
|
import { ref, onMounted, reactive,computed } from 'vue'; |
|
|
|
import homeApi from '@/api/HomeApi'; |
|
|
|
|
|
|
|
const articleImgSrc = ref(''); |
|
|
|
const title = ref(''); |
|
|
@ -11,42 +11,80 @@ 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(''); |
|
|
|
|
|
|
|
const clubMark1Src = ref('https://lfjf.rzfwq.com/jtzy/Product/pcjingwang/uploads/default/416cf8f2e000451043b1d1af74b5dbb8.png '); |
|
|
|
const clubMark2Src = ref('https://d31zlh4on95l9h.cloudfront.net/web/20241130133116/img/clubS1.b631a2c3.png'); |
|
|
|
const clubMark3Src = ref('https://lfjf.rzfwq.com/jtzy/Product/pcjingwang/uploads/default/cbd9eda094b33695bab858e08c67ae71.png'); |
|
|
|
const clubMark4Src = ref('https://d31zlh4on95l9h.cloudfront.net/web/20241130133116/img/clubS4.98fc204a.png'); |
|
|
|
|
|
|
|
// 定义响应式数据来存储从数据库获取的数据 |
|
|
|
const articleData = reactive({ |
|
|
|
articleImgSrc: '', |
|
|
|
title: '', |
|
|
|
authorAvatarSrc: '', |
|
|
|
authorName: '', |
|
|
|
publishTime: '', |
|
|
|
viewsCount: 0, |
|
|
|
commentsCount: 0, |
|
|
|
likesCount: 0, |
|
|
|
playTime: '' |
|
|
|
playTime: '', |
|
|
|
club_id: '', |
|
|
|
publishTime: '', |
|
|
|
flag_type:'' |
|
|
|
}); |
|
|
|
|
|
|
|
console.log('初始化后的articleData:', articleData); |
|
|
|
|
|
|
|
// 定义一个函数,用于将接口返回的数据映射到articleData响应式对象中 |
|
|
|
const mapResponseToArticleData = (responseData) => { |
|
|
|
if (Array.isArray(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.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); |
|
|
|
} else { |
|
|
|
console.warn('接口返回的数据格式不符合预期'); |
|
|
|
} |
|
|
|
}; |
|
|
|
|
|
|
|
// 页面加载时调用接口获取数据 |
|
|
|
onMounted(() => { |
|
|
|
axios.get('https://api.example.com/article') |
|
|
|
.then((response) => { |
|
|
|
// 直接修改articleData里的各个属性,因为它现在是reactive响应式对象 |
|
|
|
articleData.articleImgSrc = response.data.articleImgSrc; |
|
|
|
articleData.title = response.data.title; |
|
|
|
articleData.authorAvatarSrc = response.data.authorAvatarSrc; |
|
|
|
articleData.authorName = response.data.authorName; |
|
|
|
articleData.publishTime = response.data.publishTime; |
|
|
|
articleData.viewsCount = response.data.viewsCount; |
|
|
|
articleData.commentsCount = response.data.commentsCount; |
|
|
|
articleData.likesCount = response.data.likesCount; |
|
|
|
articleData.playTime = response.data.playTime; |
|
|
|
}) |
|
|
|
.catch((error) => { |
|
|
|
console.error('获取数据出错:', error); |
|
|
|
}); |
|
|
|
async function selectAll() { |
|
|
|
try { |
|
|
|
const response = await homeApi.gethomeList(); |
|
|
|
mapResponseToArticleData(response); |
|
|
|
} catch (error) { |
|
|
|
console.error('获取数据出错:', error); |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
|
selectAll(); |
|
|
|
|
|
|
|
|
|
|
|
const getColorClass = (index) => { |
|
|
|
const num = index + 1; |
|
|
|
if (num === 1) { |
|
|
|
return 'color-red'; |
|
|
|
} else if (num === 2) { |
|
|
|
return 'color-green'; |
|
|
|
} else if (num === 3) { |
|
|
|
return 'color-blue'; |
|
|
|
} |
|
|
|
return ''; |
|
|
|
}; |
|
|
|
|
|
|
|
const filteredArticleData = computed(() => { |
|
|
|
return articleData.title.filter((_, index) => articleData.flag_type[index] === 1); |
|
|
|
}); |
|
|
|
</script> |
|
|
|
|
|
|
@ -59,35 +97,46 @@ onMounted(() => { |
|
|
|
<div class="container" style="width: 600px;"> |
|
|
|
<div class="title"><b>推荐</b></div> |
|
|
|
<ul class="data-list"> |
|
|
|
<li class="data-list-li articleList" v-for="(item, index) in articleData" :key="index"> |
|
|
|
<div class="articleimg"> |
|
|
|
<div class="el-image articleimg-img"> |
|
|
|
<img :src="item.articleImgSrc" alt="文章图片"> |
|
|
|
<span class="play-icon"></span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<p>{{ item.title }}</p> |
|
|
|
<span class="articleinfo-avatar islink"> |
|
|
|
<img :src="item.authorAvatarSrc" alt="作者头像"> |
|
|
|
"{{ item.authorName }}" |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time">{{ item.publishTime }}</span> |
|
|
|
<span class="homepage-list-li-see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
"{{ item.viewsCount }}" |
|
|
|
</span> |
|
|
|
<span class="homepage-list-li-ping"> |
|
|
|
<img :src="pingSrc" alt="评论数图标"> |
|
|
|
"{{ item.commentsCount }}" |
|
|
|
</span> |
|
|
|
<span class="homepage-list-1i-zan"> |
|
|
|
<img :src="zanSrc" alt="点赞图标"> |
|
|
|
"{{ item.likesCount }}" |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
<li class="data-list-li articleList" v-for="(title, index) in articleData.title" :key="index"> |
|
|
|
<!-- 下面继续展示对应数据的渲染,和之前类似 --> |
|
|
|
<div class="articleimg"> |
|
|
|
<div class="el-image articleimg-img"> |
|
|
|
<img :src="articleData.articleImgSrc[index]" alt="文章图片"> |
|
|
|
<span class="play-icon"></span> |
|
|
|
</div> |
|
|
|
<div class="club"> |
|
|
|
<span class="club_img"> |
|
|
|
<img v-if="articleData.club_id[index] === 1" :src="clubMark1Src" alt="club_id为1的角标"> |
|
|
|
<img v-else-if="articleData.club_id[index] === 2" :src="clubMark2Src" alt="club_id为2的角标"> |
|
|
|
<img v-else-if="articleData.club_id[index] === 3" :src="clubMark3Src" alt="club_id为3的角标"> |
|
|
|
<img v-else-if="articleData.club_id[index] === 4" :src="clubMark4Src" alt="club_id为4的角标"> |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<p>{{ title }}</p> |
|
|
|
<span class="articleinfo-avatar islink"> |
|
|
|
<img :src="articleData.authorAvatarSrc[index]" alt="作者头像"> |
|
|
|
{{ articleData.authorName[index] }} |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time" alt="发布时间"> |
|
|
|
{{ articleData.publishTime[index] }} |
|
|
|
</span> |
|
|
|
<span class="homepage-list-li-see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
{{ articleData.viewsCount[index] }} |
|
|
|
</span> |
|
|
|
<span class="homepage-list-li-ping"> |
|
|
|
<img :src="pingSrc" alt="评论数图标"> |
|
|
|
{{ articleData.commentsCount[index] }} |
|
|
|
</span> |
|
|
|
<span class="homepage-list-1i-zan"> |
|
|
|
<img :src="zanSrc" alt="点赞图标"> |
|
|
|
{{ articleData.likesCount[index] }} |
|
|
|
</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
</div> |
|
|
|
<div class="sidebar-right" style="width: 400px; float: right;"> |
|
|
|
<div> |
|
|
@ -95,25 +144,25 @@ onMounted(() => { |
|
|
|
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="(item, index) in articleData" :key="index"> |
|
|
|
<div class="articleimg"> |
|
|
|
<div class="el-image articleimg-img"> |
|
|
|
<img :src="item.articleImgSrc" alt="文章图片"> |
|
|
|
<span class="corner-mark">1</span> |
|
|
|
<span class="play-time">{{ item.playTime }}</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<h5>{{ item.title }}</h5> |
|
|
|
<span class="homepage-list-li-see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
"{{ item.viewsCount }}" |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time">{{ item.publishTime }}</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
<ul class="data-list" > |
|
|
|
<li class="data-list-li articleList" v-for="(title, index) in filteredArticleData" :key="index"> |
|
|
|
<div class="articleimg" > |
|
|
|
<div class="el-image articleimg-img" > |
|
|
|
<img :src="articleData.articleImgSrc[index]" alt="文章图片"> |
|
|
|
<span :class="['corner-mark', getColorClass(index)]">{{ index + 1 }}</span> |
|
|
|
<span class="play-time">{{ articleData.playTime[index] }}</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<h5>{{ title }}</h5> |
|
|
|
<span class="homepage-list-li-see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
{{ articleData.viewsCount[index] }} |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time">{{ articleData.publishTime[index] }}</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
@ -215,17 +264,29 @@ body { |
|
|
|
display: flex; |
|
|
|
} |
|
|
|
|
|
|
|
.corner-mark { |
|
|
|
.corner-mark { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
left: 0; |
|
|
|
background-color: red; |
|
|
|
background-color: rgb(128, 128, 128); |
|
|
|
color: white; |
|
|
|
padding: 2px 5px; |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
} |
|
|
|
|
|
|
|
.color-red { |
|
|
|
background-color: red; |
|
|
|
} |
|
|
|
|
|
|
|
.color-green { |
|
|
|
background-color: rgb(255, 102, 0); |
|
|
|
} |
|
|
|
|
|
|
|
.color-blue { |
|
|
|
background-color: rgb(255, 196, 0); |
|
|
|
} |
|
|
|
|
|
|
|
.play-time { |
|
|
|
position: absolute; |
|
|
|
bottom: 10%; |
|
|
@ -236,4 +297,22 @@ body { |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
} |
|
|
|
|
|
|
|
.club { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整容器大小等样式 */ |
|
|
|
|
|
|
|
width: 10px; |
|
|
|
height: 10px; |
|
|
|
} |
|
|
|
.club_img img { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整图片的大小等其他样式,以下是示例 */ |
|
|
|
width: 15px; /* 假设调整宽度 */ |
|
|
|
height: 15px; /* 假设调整高度 */ |
|
|
|
} |
|
|
|
</style> |