Browse Source

接口对接,调整

home_zwk
zhaowenkang 7 months ago
parent
commit
5d267c6ac8
  1. 125
      vueHomilyLink/src/views/HomeView.vue
  2. 4
      vueHomilyLink/vite.config.js

125
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 => {
// articleDataarticleData2
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{
/*让页面分为左右结构*/

4
vueHomilyLink/vite.config.js

@ -18,8 +18,8 @@ export default defineConfig({
server: {
proxy: {
'/api': {
// target: 'http://192.168.8.191:8080',
target: 'http://localhost:8080',
target: 'http://192.168.8.191:8080',
// target: 'http://localhost:8080',
changeOrigin: true,
rewrite: (path) => path.replace(/^\/api/, '')
}

Loading…
Cancel
Save