|
|
@ -1,11 +1,12 @@ |
|
|
|
<script setup> |
|
|
|
import Nav from '@/components/Nav.vue'; |
|
|
|
import { ref, onMounted, reactive,computed } from 'vue'; |
|
|
|
import { ref, onMounted, reactive, computed } from 'vue'; |
|
|
|
import homeApi from '@/api/HomeApi'; |
|
|
|
|
|
|
|
const seeSrc = ref(''); |
|
|
|
const pingSrc = ref(''); |
|
|
|
const zanSrc = ref(''); |
|
|
|
const play = 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'); |
|
|
@ -24,7 +25,7 @@ const articleData = reactive({ |
|
|
|
playTime: '', |
|
|
|
club_id: '', |
|
|
|
publishTime: '', |
|
|
|
flag_type:'' |
|
|
|
flag_type: '' |
|
|
|
}); |
|
|
|
|
|
|
|
// 定义一个函数,用于将接口返回的数据映射到articleData响应式对象中 |
|
|
@ -60,7 +61,7 @@ async function selectAll() { |
|
|
|
try { |
|
|
|
const response = await homeApi.gethomeList(); |
|
|
|
mapResponseToArticleData(response.data); |
|
|
|
|
|
|
|
|
|
|
|
} catch (error) { |
|
|
|
console.error('获取数据出错:', error); |
|
|
|
} |
|
|
@ -72,7 +73,7 @@ selectAll(); |
|
|
|
|
|
|
|
// 精选视频接口 |
|
|
|
const articleData2 = ref([]); |
|
|
|
function fetchData (){ |
|
|
|
function fetchData() { |
|
|
|
homeApi.getHomeVideo().then(response => { |
|
|
|
// 将articleData响应式对象赋值给articleData2 |
|
|
|
articleData2.value = response.data; |
|
|
@ -83,7 +84,7 @@ function fetchData (){ |
|
|
|
const hours = ('0' + date.getHours()).slice(-2); |
|
|
|
const minutes = ('0' + date.getMinutes()).slice(-2); |
|
|
|
return { |
|
|
|
...item, |
|
|
|
...item, |
|
|
|
releaseTime: `${month}-${day} ${hours}:${minutes}` |
|
|
|
}; |
|
|
|
}); |
|
|
@ -92,7 +93,7 @@ function fetchData (){ |
|
|
|
console.error('获取数据出错:', error); |
|
|
|
}); |
|
|
|
}; |
|
|
|
fetchData (); |
|
|
|
fetchData(); |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@ -122,49 +123,56 @@ const getColorClass = (index) => { |
|
|
|
<div class="container" style="width: 600px;"> |
|
|
|
<div class="title"><b>推荐</b></div> |
|
|
|
<ul class="data-list"> |
|
|
|
<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><b>{{ title }}</b></p> |
|
|
|
<span class="articleinfo-avatar islink" style="font-size: 14px;"> |
|
|
|
<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> |
|
|
|
<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="文章图片"> |
|
|
|
<div class="play-icon-container"> |
|
|
|
<span class="play-icon" v-if="articleData.flag_type[index]===1"></span> |
|
|
|
<span class="play-icon-background" v-if="articleData.flag_type[index]===1"></span> |
|
|
|
</div> |
|
|
|
</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><b>{{ title }}</b></p> |
|
|
|
<div class="right-inline"> |
|
|
|
<!-- HomilyLink --> |
|
|
|
<div class="right-item"> |
|
|
|
<img :src="articleData.authorAvatarSrc[index]" class="img1"> |
|
|
|
<div>{{ articleData.authorName[index] }}</div> |
|
|
|
</div> |
|
|
|
<!-- 日期 --> |
|
|
|
<div class="right-item">{{ articleData.publishTime[index] }}</div> |
|
|
|
<!-- 观看 --> |
|
|
|
<div class="right-item"> |
|
|
|
<img :src="seeSrc" class="img2"> |
|
|
|
<div>{{ articleData.viewsCount[index] }}</div> |
|
|
|
</div> |
|
|
|
<!-- 评论 --> |
|
|
|
<div class="right-item"> |
|
|
|
<img :src="pingSrc" class="img2"> |
|
|
|
<div>{{ articleData.commentsCount[index] }}</div> |
|
|
|
</div> |
|
|
|
<!-- 点赞 --> |
|
|
|
<div class="right-item"> |
|
|
|
<img :src="zanSrc" class="img2"> |
|
|
|
<div>{{ articleData.likesCount[index] }}</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
</div> |
|
|
|
|
|
|
|
|
|
|
|
<!-- 精选视频 --> |
|
|
|
<div class="sidebar-right" style="width: 400px; float: right;"> |
|
|
|
<div> |
|
|
@ -172,159 +180,209 @@ const getColorClass = (index) => { |
|
|
|
src="" |
|
|
|
alt style="width: 20px; height: 20px; margin-right: 5px; vertical-align: middle;">精选视频 |
|
|
|
</div> |
|
|
|
<ul class="data-list" > |
|
|
|
<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="article.cover" alt="文章图片"> |
|
|
|
<span :class="['corner-mark', getColorClass(index)]">{{ index + 1 }}</span> |
|
|
|
<span class="play-time">{{ article.videoDuration }}</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<span class="articletitle">{{ article.name }}</span> |
|
|
|
<span class="see"> |
|
|
|
<img :src="seeSrc" alt="浏览量图标"> |
|
|
|
{{ article.viewCount }} |
|
|
|
</span> |
|
|
|
<span class="articleinfo-time">{{ article.releaseTime }}</span> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
<div class="articleimg"> |
|
|
|
<div class="el-image articleimg-img"> |
|
|
|
<img :src="article.cover" alt="文章图片"> |
|
|
|
<span :class="['corner-mark', getColorClass(index)]">{{ index + 1 }}</span> |
|
|
|
<span class="play-time">{{ article.videoDuration }}</span> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
<div class="articleinfo"> |
|
|
|
<span class="articletitle">{{ article.name }}</span> |
|
|
|
<div class="right-inline"> |
|
|
|
<!-- 观看 --> |
|
|
|
<div class="right-item"> |
|
|
|
<img :src="seeSrc" class="img2"> |
|
|
|
<div>{{ article.viewCount }}</div> |
|
|
|
</div> |
|
|
|
<!-- 日期 --> |
|
|
|
<div class="right-item">{{ article.releaseTime }}</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</li> |
|
|
|
</ul> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</div> |
|
|
|
</template> |
|
|
|
|
|
|
|
<style scoped> |
|
|
|
.articletitle{ |
|
|
|
.img1 { |
|
|
|
width: 22px; |
|
|
|
height: 22px; |
|
|
|
} |
|
|
|
|
|
|
|
.img2 { |
|
|
|
width: 18px; |
|
|
|
height: 18px; |
|
|
|
} |
|
|
|
|
|
|
|
.right-inline { |
|
|
|
display: flex; |
|
|
|
margin-bottom: 5px; |
|
|
|
align-items: center; |
|
|
|
font-size: 16px; |
|
|
|
} |
|
|
|
|
|
|
|
.right-item { |
|
|
|
display: flex; |
|
|
|
color: #8e8e8e; |
|
|
|
font-size: 14px; |
|
|
|
margin-right: 18px; |
|
|
|
align-items: center; |
|
|
|
} |
|
|
|
|
|
|
|
.articletitle { |
|
|
|
display: block; |
|
|
|
font-size: 16px; |
|
|
|
margin-bottom: 20px; |
|
|
|
margin-bottom: 30px; |
|
|
|
} |
|
|
|
|
|
|
|
.play-icon { |
|
|
|
width: 0; |
|
|
|
height: 0; |
|
|
|
border-style: solid; |
|
|
|
border-width: 10px 0 10px 16px; /* 根据需要调整三角形大小 */ |
|
|
|
border-color: transparent transparent transparent rgba(255, 255, 255, 0.8); /* 白色半透明三角形,可调整颜色 */ |
|
|
|
position: absolute; |
|
|
|
top: 45%; |
|
|
|
left: 50%; |
|
|
|
transform: translate(-50%, -50%); |
|
|
|
width: 0; |
|
|
|
height: 0; |
|
|
|
border-style: solid; |
|
|
|
border-width: 10px 0 10px 16px; |
|
|
|
/* 根据需要调整三角形大小 */ |
|
|
|
border-color: transparent transparent transparent rgba(255, 255, 255, 1); |
|
|
|
/* 白色半透明三角形,可调整颜色 */ |
|
|
|
position: absolute; |
|
|
|
bottom: 180%; |
|
|
|
left: 150%; |
|
|
|
transform: translate(150%, -50%); |
|
|
|
z-index: 1; |
|
|
|
} |
|
|
|
|
|
|
|
.play-icon-container { |
|
|
|
width: 30px; |
|
|
|
/* 可以根据需求调整这个容器宽度,用于控制整体大小和布局 */ |
|
|
|
height: 30px; |
|
|
|
/* 可以根据需求调整这个容器高度,用于控制整体大小和布局 */ |
|
|
|
position: relative; |
|
|
|
} |
|
|
|
.daohang{ |
|
|
|
height: 32px; |
|
|
|
|
|
|
|
.play-icon-background { |
|
|
|
content: ""; |
|
|
|
width: 35px; |
|
|
|
/* 调整圆形的直径大小 */ |
|
|
|
height: 35px; |
|
|
|
/* 调整圆形的直径大小 */ |
|
|
|
border-radius: 50%; |
|
|
|
background-color: rgba(0, 0, 0, 0.6); |
|
|
|
position: absolute; |
|
|
|
bottom: 190%; |
|
|
|
left: 75%; |
|
|
|
transform: translateX(100%); |
|
|
|
z-index: 0; |
|
|
|
} |
|
|
|
.container{ |
|
|
|
margin-right: 0; |
|
|
|
margin-left: auto; |
|
|
|
|
|
|
|
|
|
|
|
.daohang { |
|
|
|
height: 32px; |
|
|
|
} |
|
|
|
.sidebar-right{ |
|
|
|
margin-right: auto; |
|
|
|
margin-left: 0; |
|
|
|
|
|
|
|
.container { |
|
|
|
margin-right: 0; |
|
|
|
margin-left: auto; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
.sidebar-right { |
|
|
|
margin-right: auto; |
|
|
|
margin-left: 0; |
|
|
|
} |
|
|
|
|
|
|
|
body { |
|
|
|
font-family: Arial, sans-serif; |
|
|
|
} |
|
|
|
.title { |
|
|
|
font-size: 24px; |
|
|
|
color: #333; |
|
|
|
padding: 10px 0; |
|
|
|
|
|
|
|
} |
|
|
|
.data-list-li { |
|
|
|
display: flex; |
|
|
|
align-items: flex-start; |
|
|
|
padding: 10px 0; |
|
|
|
} |
|
|
|
.articleimg { |
|
|
|
position: relative; /* 设置相对定位 */ |
|
|
|
width: 150px; |
|
|
|
height: 100px; |
|
|
|
margin-right: 10px; /* 减少右边距以让文字更靠近图片 */ |
|
|
|
border-radius: 5px; |
|
|
|
/* overflow: hidden; */ |
|
|
|
} |
|
|
|
.articleimg-img img { |
|
|
|
width: 150px; |
|
|
|
height: 90px; |
|
|
|
object-fit: cover; |
|
|
|
} |
|
|
|
.articleinfo { |
|
|
|
flex-grow: 1; |
|
|
|
font-size: 20px; |
|
|
|
margin: 0; |
|
|
|
padding: 0; |
|
|
|
} |
|
|
|
.articleinfo p { |
|
|
|
margin: 0; /* 移除外边距 */ |
|
|
|
font-size: 20px; |
|
|
|
color: #555; |
|
|
|
margin-bottom: 7%; |
|
|
|
} |
|
|
|
.right_inline { |
|
|
|
display: inline-block; |
|
|
|
vertical-align: top; |
|
|
|
} |
|
|
|
.articleinfo-avatar { |
|
|
|
margin-left: 0; |
|
|
|
display: inline-block; |
|
|
|
} |
|
|
|
.articleinfo-avatar img { |
|
|
|
width: 20px; |
|
|
|
height: 20px; |
|
|
|
border-radius: 50%; |
|
|
|
} |
|
|
|
.articleinfo-time { |
|
|
|
font-size: 13px; |
|
|
|
color: #000000; |
|
|
|
margin-left: 10px; |
|
|
|
} |
|
|
|
.homepage-list-li-see, |
|
|
|
.homepage-list-li-ping, |
|
|
|
.homepage-list-1i-zan { |
|
|
|
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{ |
|
|
|
/*让页面分为左右结构*/ |
|
|
|
display: flex; |
|
|
|
margin-top: 30px |
|
|
|
} |
|
|
|
|
|
|
|
.corner-mark { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
left: 0; |
|
|
|
background-color: rgb(128, 128, 128); |
|
|
|
color: white; |
|
|
|
padding: 2px 5px; |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
font-family: Arial, sans-serif; |
|
|
|
} |
|
|
|
|
|
|
|
.title { |
|
|
|
font-size: 24px; |
|
|
|
color: #333; |
|
|
|
padding: 10px 0; |
|
|
|
|
|
|
|
} |
|
|
|
|
|
|
|
.data-list-li { |
|
|
|
display: flex; |
|
|
|
align-items: flex-start; |
|
|
|
padding: 10px 0; |
|
|
|
} |
|
|
|
|
|
|
|
.articleimg { |
|
|
|
position: relative; |
|
|
|
/* 设置相对定位 */ |
|
|
|
width: 150px; |
|
|
|
height: 100px; |
|
|
|
margin-right: 10px; |
|
|
|
/* 减少右边距以让文字更靠近图片 */ |
|
|
|
border-radius: 5px; |
|
|
|
/* overflow: hidden; */ |
|
|
|
} |
|
|
|
|
|
|
|
.articleimg-img img { |
|
|
|
width: 150px; |
|
|
|
height: 90px; |
|
|
|
object-fit: cover; |
|
|
|
} |
|
|
|
|
|
|
|
.articleinfo { |
|
|
|
flex-grow: 1; |
|
|
|
font-size: 20px; |
|
|
|
margin: 0; |
|
|
|
padding: 0; |
|
|
|
} |
|
|
|
|
|
|
|
.articleinfo p { |
|
|
|
margin: 0; |
|
|
|
/* 移除外边距 */ |
|
|
|
font-size: 20px; |
|
|
|
color: #555; |
|
|
|
margin-bottom: 10%; |
|
|
|
} |
|
|
|
|
|
|
|
.right_inline { |
|
|
|
display: inline-block; |
|
|
|
vertical-align: top; |
|
|
|
} |
|
|
|
|
|
|
|
.articleinfo-avatar { |
|
|
|
margin-left: 0; |
|
|
|
display: inline-block; |
|
|
|
} |
|
|
|
|
|
|
|
.articleinfo-avatar img { |
|
|
|
width: 20px; |
|
|
|
height: 20px; |
|
|
|
border-radius: 50%; |
|
|
|
} |
|
|
|
|
|
|
|
.articleinfo-time { |
|
|
|
font-size: 13px; |
|
|
|
color: #000000; |
|
|
|
margin-left: 10px; |
|
|
|
} |
|
|
|
|
|
|
|
.class123 { |
|
|
|
/*让页面分为左右结构*/ |
|
|
|
display: flex; |
|
|
|
margin-top: 30px |
|
|
|
} |
|
|
|
|
|
|
|
.corner-mark { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
left: 0; |
|
|
|
background-color: rgb(128, 128, 128); |
|
|
|
color: white; |
|
|
|
padding: 2px 5px; |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
} |
|
|
|
|
|
|
|
.color-red { |
|
|
|
background-color: red; |
|
|
|
background-color: red; |
|
|
|
} |
|
|
|
|
|
|
|
.color-green { |
|
|
@ -336,31 +394,35 @@ body { |
|
|
|
} |
|
|
|
|
|
|
|
.play-time { |
|
|
|
position: absolute; |
|
|
|
bottom: 4%; |
|
|
|
right: 0; |
|
|
|
background-color: rgba(0, 0, 0, 0.5); /* 半透明黑色背景,可调整透明度和颜色 */ |
|
|
|
color: white; |
|
|
|
padding: 2px 5px; |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
position: absolute; |
|
|
|
bottom: 4%; |
|
|
|
right: 0; |
|
|
|
background-color: rgba(0, 0, 0, 0.5); |
|
|
|
/* 半透明黑色背景,可调整透明度和颜色 */ |
|
|
|
color: white; |
|
|
|
padding: 2px 5px; |
|
|
|
border-radius: 2px; |
|
|
|
font-size: 12px; |
|
|
|
} |
|
|
|
|
|
|
|
.club { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整容器大小等样式 */ |
|
|
|
|
|
|
|
width: 10px; |
|
|
|
height: 10px; |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整容器大小等样式 */ |
|
|
|
|
|
|
|
width: 10px; |
|
|
|
height: 10px; |
|
|
|
} |
|
|
|
|
|
|
|
.club_img img { |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整图片的大小等其他样式,以下是示例 */ |
|
|
|
width: 15px; /* 假设调整宽度 */ |
|
|
|
height: 15px; /* 假设调整高度 */ |
|
|
|
} |
|
|
|
position: absolute; |
|
|
|
top: 0; |
|
|
|
right: 0; |
|
|
|
/* 可以根据实际需求调整图片的大小等其他样式,以下是示例 */ |
|
|
|
width: 15px; |
|
|
|
/* 假设调整宽度 */ |
|
|
|
height: 15px; |
|
|
|
/* 假设调整高度 */ |
|
|
|
} |
|
|
|
</style> |