UserInfo
MINAMI 7 days ago
commit f583c12570

@ -2,6 +2,9 @@ import { createRouter, createWebHistory } from 'vue-router'
import Home from './views/Home.vue' import Home from './views/Home.vue'
import ArticleDetail from './components/ArticleDetail.vue'; // 假设你有一个显示文章详情的组件 import ArticleDetail from './components/ArticleDetail.vue'; // 假设你有一个显示文章详情的组件
import UserInfo from './views/UserAccount.vue'; import UserInfo from './views/UserAccount.vue';
import UserDetail from './views/UserDetail.vue';
const routes = [ const routes = [
{ path: '/', component: Home }, { path: '/', component: Home },
{ {
@ -15,6 +18,11 @@ const routes = [
name: 'UserInfo', name: 'UserInfo',
component: UserInfo, component: UserInfo,
}, },
{
path: '/user/:id',
name: 'UserDetail',
component: UserDetail
}
] ]
const router = createRouter({ const router = createRouter({

@ -1,6 +1,7 @@
<template> <template>
<el-container> <el-container>
<el-header> <el-header>
<el-button type="primary" @click="goBack"></el-button>
<h1>知乎个人主页</h1> <h1>知乎个人主页</h1>
</el-header> </el-header>
<el-main> <el-main>
@ -24,12 +25,19 @@
<el-image :src="post.cover" class="post-cover"></el-image> <el-image :src="post.cover" class="post-cover"></el-image>
</el-col> </el-col>
<el-col :span="18"> <el-col :span="18">
<el-link :href="`/post/${post.id}`" target="_blank" class="post-title">{{ post.title }}</el-link> <router-link :to="`/post/${post.id}`" class="post-title">{{ post.title }}</router-link>
<p class="post-summary">{{ post.summary }}</p> <p class="post-summary">{{ post.summary }}</p>
<div class="post-stats"> <div class="post-stats">
<span><i class="el-icon-thumb"></i> {{ post.likes }} 点赞</span> <span><i class="el-icon-thumb"></i> {{ post.likes }} 点赞</span>
<span><i class="el-icon-chat-dot-round"></i> {{ post.comments }} 评论</span> <span><i class="el-icon-chat-dot-round"></i> {{ post.comments }} 评论</span>
</div> </div>
<div class="post-actions">
<el-button type="text" @click="toggleEdit(post.id)"></el-button>
<div v-if="post.editing" class="edit-options">
<el-button type="danger" size="small" @click="deletePost(post.id)"></el-button>
<el-button type="primary" size="small" @click="rewritePost(post.id)"></el-button>
</div>
</div>
</el-col> </el-col>
</el-row> </el-row>
</el-list-item> </el-list-item>
@ -43,12 +51,15 @@
<el-image :src="collection.cover" class="post-cover"></el-image> <el-image :src="collection.cover" class="post-cover"></el-image>
</el-col> </el-col>
<el-col :span="18"> <el-col :span="18">
<el-link :href="`/post/${collection.id}`" target="_blank" class="post-title">{{ collection.title }}</el-link> <router-link :to="`/post/${collection.id}`" class="post-title">{{ collection.title }}</router-link>
<p class="post-summary">{{ collection.summary }}</p> <p class="post-summary">{{ collection.summary }}</p>
<div class="post-stats"> <div class="post-stats">
<span><i class="el-icon-thumb"></i> {{ collection.likes }} 点赞</span> <span><i class="el-icon-thumb"></i> {{ collection.likes }} 点赞</span>
<span><i class="el-icon-chat-dot-round"></i> {{ collection.comments }} 评论</span> <span><i class="el-icon-chat-dot-round"></i> {{ collection.comments }} 评论</span>
</div> </div>
<div class="post-actions">
<el-button type="danger" size="small" @click="deleteCollection(collection.id)"></el-button>
</div>
</el-col> </el-col>
</el-row> </el-row>
</el-list-item> </el-list-item>
@ -59,10 +70,12 @@
<el-list-item v-for="follower in user.followers" :key="follower.id"> <el-list-item v-for="follower in user.followers" :key="follower.id">
<el-row :gutter="10" align="middle"> <el-row :gutter="10" align="middle">
<el-col :span="4"> <el-col :span="4">
<router-link :to="`/user/${follower.id}`">
<el-avatar :src="follower.avatar" class="follower-avatar"></el-avatar> <el-avatar :src="follower.avatar" class="follower-avatar"></el-avatar>
</router-link>
</el-col> </el-col>
<el-col :span="16"> <el-col :span="16">
<el-link :href="`/user/${follower.id}`" target="_blank" class="follower-name">{{ follower.name }}</el-link> <router-link :to="`/user/${follower.id}`" class="follower-name">{{ follower.name }}</router-link>
<p class="follower-level">等级: {{ follower.level }}</p> <p class="follower-level">等级: {{ follower.level }}</p>
</el-col> </el-col>
<el-col :span="4"> <el-col :span="4">
@ -81,16 +94,18 @@
<script setup> <script setup>
import { ref, onMounted } from 'vue' import { ref, onMounted } from 'vue'
import { useRouter } from 'vue-router'
const router = useRouter()
const tab = ref('posts') const tab = ref('posts')
const user = ref({ const user = ref({
avatar: 'https://via.placeholder.com/150', avatar: 'https://via.placeholder.com/150',
name: '张三', name: '张三',
bio: '这是一个个人简介,介绍我的兴趣爱好、职业背景等。', bio: '这是一个个人简介,介绍我的兴趣爱好、职业背景等。',
posts: [ posts: [
{ id: 1, title: '第一篇文章标题', summary: '这是第一篇文章的摘要', likes: 100, comments: 50, cover: 'https://via.placeholder.com/200x150' }, { id: 1, title: '第一篇文章标题', summary: '这是第一篇文章的摘要', likes: 100, comments: 50, cover: 'https://via.placeholder.com/200x150', editing: false },
{ id: 2, title: '第二篇文章标题', summary: '这是第二篇文章的摘要', likes: 200, comments: 75, cover: 'https://via.placeholder.com/200x150' }, { id: 2, title: '第二篇文章标题', summary: '这是第二篇文章的摘要', likes: 200, comments: 75, cover: 'https://via.placeholder.com/200x150', editing: false },
{ id: 3, title: '第三篇文章标题', summary: '这是第三篇文章的摘要', likes: 150, comments: 60, cover: 'https://via.placeholder.com/200x150' } { id: 3, title: '第三篇文章标题', summary: '这是第三篇文章的摘要', likes: 150, comments: 60, cover: 'https://via.placeholder.com/200x150', editing: false }
], ],
collections: [ collections: [
{ id: 1, title: '收藏的第一篇文章', summary: '这是收藏的第一篇文章的摘要', likes: 80, comments: 30, cover: 'https://via.placeholder.com/200x150' }, { id: 1, title: '收藏的第一篇文章', summary: '这是收藏的第一篇文章的摘要', likes: 80, comments: 30, cover: 'https://via.placeholder.com/200x150' },
@ -112,9 +127,9 @@ onMounted(() => {
name: '张三', name: '张三',
bio: '这是一个个人简介,介绍我的兴趣爱好、职业背景等。', bio: '这是一个个人简介,介绍我的兴趣爱好、职业背景等。',
posts: [ posts: [
{ id: 1, title: '第一篇文章标题', summary: '这是第一篇文章的摘要', likes: 100, comments: 50, cover: 'https://via.placeholder.com/200x150' }, { id: 1, title: '第一篇文章标题', summary: '这是第一篇文章的摘要', likes: 100, comments: 50, cover: 'https://via.placeholder.com/200x150', editing: false },
{ id: 2, title: '第二篇文章标题', summary: '这是第二篇文章的摘要', likes: 200, comments: 75, cover: 'https://via.placeholder.com/200x150' }, { id: 2, title: '第二篇文章标题', summary: '这是第二篇文章的摘要', likes: 200, comments: 75, cover: 'https://via.placeholder.com/200x150', editing: false },
{ id: 3, title: '第三篇文章标题', summary: '这是第三篇文章的摘要', likes: 150, comments: 60, cover: 'https://via.placeholder.com/200x150' } { id: 3, title: '第三篇文章标题', summary: '这是第三篇文章的摘要', likes: 150, comments: 60, cover: 'https://via.placeholder.com/200x150', editing: false }
], ],
collections: [ collections: [
{ id: 1, title: '收藏的第一篇文章', summary: '这是收藏的第一篇文章的摘要', likes: 80, comments: 30, cover: 'https://via.placeholder.com/200x150' }, { id: 1, title: '收藏的第一篇文章', summary: '这是收藏的第一篇文章的摘要', likes: 80, comments: 30, cover: 'https://via.placeholder.com/200x150' },
@ -134,6 +149,41 @@ onMounted(() => {
const unfollow = (followerId) => { const unfollow = (followerId) => {
user.value.followers = user.value.followers.filter(follower => follower.id !== followerId) user.value.followers = user.value.followers.filter(follower => follower.id !== followerId)
} }
//
const goBack = () => {
router.back()
}
//
const toggleEdit = (postId) => {
const post = user.value.posts.find(p => p.id === postId);
if (post) {
post.editing = !post.editing;
}
}
//
const deletePost = (postId) => {
user.value.posts = user.value.posts.filter(post => post.id !== postId);
}
//
const rewritePost = (postId) => {
//
console.log(`正在改写文章 ${postId}`);
const post = user.value.posts.find(p => p.id === postId);
if (post) {
post.title = `改写后的文章标题 ${postId}`;
post.summary = `改写后的文章摘要 ${postId}`;
}
toggleEdit(postId); //
}
//
const deleteCollection = (collectionId) => {
user.value.collections = user.value.collections.filter(collection => collection.id !== collectionId);
}
</script> </script>
<style scoped> <style scoped>
@ -211,6 +261,14 @@ const unfollow = (followerId) => {
margin-right: 10px; margin-right: 10px;
} }
.post-actions {
margin-top: 5px;
}
.edit-options {
margin-top: 5px;
}
.follower-avatar { .follower-avatar {
width: 50px; width: 50px;
height: 50px; height: 50px;

Loading…
Cancel
Save