Merge branch 'main' of https://bdgit.educoder.net/pmc9py4oq/software_teamwork
	
		
	
				
					
				
			
						commit
						a0e9b5e4c0
					
				| @ -0,0 +1,98 @@ | ||||
| <template> | ||||
|   <div class="detail-container"> | ||||
|     <button @click="$router.go(-1)" class="back-btn">返回</button> | ||||
|      | ||||
|     <div v-if="currentNotice" class="notice-detail"> | ||||
|       <h1 class="detail-title">{{ currentNotice.title }}</h1> | ||||
|       <div class="meta-info"> | ||||
|         <span class="time">{{ currentNotice.time }}</span> | ||||
|         <span class="notice-id">ID: {{ $route.params.id }}</span> | ||||
|       </div> | ||||
|       <div class="content-box"> | ||||
|         {{ currentNotice.content }} | ||||
|       </div> | ||||
|     </div> | ||||
| 
 | ||||
|     <div v-else class="loading"> | ||||
|       {{ errorMessage || '正在加载通知详情...' }} | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <script> | ||||
| const mockFetchNotice = (id) => { | ||||
|   return new Promise((resolve) => { | ||||
|     setTimeout(() => { | ||||
|       const notices = [ | ||||
|         { id: 1, title: "系统维护通知", /* 其他字段 */ }, | ||||
|         { id: 2, title: "新功能上线", /* 其他字段 */ } | ||||
|       ] | ||||
|       resolve(notices.find(n => n.id === Number(id))) | ||||
|     }, 500) | ||||
|   }) | ||||
| } | ||||
| 
 | ||||
| export default { | ||||
|   props: ['id'], // 通过路由props接收参数 | ||||
|   data() { | ||||
|     return { | ||||
|       currentNotice: null, | ||||
|       errorMessage: '' | ||||
|     } | ||||
|   }, | ||||
|   async created() { | ||||
|     try { | ||||
|       const data = await mockFetchNotice(this.id) | ||||
|       if (data) { | ||||
|         this.currentNotice = data | ||||
|       } else { | ||||
|         this.errorMessage = '通知不存在' | ||||
|       } | ||||
|     } catch (error) { | ||||
|       this.errorMessage = '加载失败,请稍后重试' | ||||
|     } | ||||
|   } | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <style scoped> | ||||
| .detail-container { | ||||
|   max-width: 800px; | ||||
|   margin: 20px auto; | ||||
|   padding: 30px; | ||||
|   background-color: #fff; | ||||
|   border-radius: 12px; | ||||
|   box-shadow: 0 4px 6px rgba(0,0,0,0.1); | ||||
| } | ||||
| 
 | ||||
| .back-btn { | ||||
|   padding: 8px 16px; | ||||
|   background-color: #f0f0f0; | ||||
|   border: 1px solid #ddd; | ||||
|   border-radius: 4px; | ||||
|   cursor: pointer; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| 
 | ||||
| .meta-info { | ||||
|   color: #666; | ||||
|   font-size: 0.9em; | ||||
|   margin: 10px 0; | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
| } | ||||
| 
 | ||||
| .content-box { | ||||
|   line-height: 1.8; | ||||
|   padding: 20px; | ||||
|   background-color: #f9f9f9; | ||||
|   border-radius: 8px; | ||||
|   margin-top: 15px; | ||||
| } | ||||
| 
 | ||||
| .loading { | ||||
|   text-align: center; | ||||
|   padding: 50px; | ||||
|   color: #888; | ||||
| } | ||||
| </style> | ||||
					Loading…
					
					
				
		Reference in new issue