1
This commit is contained in:
		
							parent
							
								
									3d56a3d6b4
								
							
						
					
					
						commit
						28754c86d5
					
				| @ -4,7 +4,7 @@ | ||||
| 		<meta charset="UTF-8" /> | ||||
| 		<link rel="icon" href="/favicon.ico" /> | ||||
| 		<meta name="viewport" content="width=device-width, initial-scale=1.0" /> | ||||
| 		<title>Vite App</title> | ||||
| 		<title>洛阳百姓问政</title> | ||||
| 	</head> | ||||
| 	<body style="margin: 0;"> | ||||
| 
 | ||||
| @ -13,4 +13,4 @@ | ||||
| 		<script type="module" src="/src/main.js"></script> | ||||
| 
 | ||||
| 	</body> | ||||
| </html> | ||||
| </html> | ||||
|  | ||||
							
								
								
									
										7
									
								
								node_modules/.vite/_metadata.json
									
									
									
										generated
									
									
										vendored
									
									
								
							
							
						
						
									
										7
									
								
								node_modules/.vite/_metadata.json
									
									
									
										generated
									
									
										vendored
									
									
								
							| @ -1,7 +1,12 @@ | ||||
| { | ||||
|   "hash": "fa4efea0", | ||||
|   "browserHash": "4777f668", | ||||
|   "browserHash": "c6181f89", | ||||
|   "optimized": { | ||||
|     "axios": { | ||||
|       "file": "E:/小程序/百姓问政PC/pc/node_modules/.vite/axios.js", | ||||
|       "src": "E:/小程序/百姓问政PC/pc/node_modules/axios/index.js", | ||||
|       "needsInterop": false | ||||
|     }, | ||||
|     "vue": { | ||||
|       "file": "E:/小程序/百姓问政PC/pc/node_modules/.vite/vue.js", | ||||
|       "src": "E:/小程序/百姓问政PC/pc/node_modules/vue/dist/vue.runtime.esm-bundler.js", | ||||
|  | ||||
							
								
								
									
										2062
									
								
								node_modules/.vite/axios.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										2062
									
								
								node_modules/.vite/axios.js
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										7
									
								
								node_modules/.vite/axios.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								node_modules/.vite/axios.js.map
									
									
									
										generated
									
									
										vendored
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 4.2 KiB After Width: | Height: | Size: 4.1 KiB | 
							
								
								
									
										13
									
								
								src/App.vue
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								src/App.vue
									
									
									
									
									
								
							| @ -21,16 +21,25 @@ | ||||
| 	// ... | ||||
| </script> | ||||
| <template> | ||||
| 	<n-config-provider :theme-overrides="themeOverrides"> | ||||
|   <n-message-provider> | ||||
|   <n-config-provider :theme-overrides="themeOverrides"> | ||||
| 		<div id="app" v-wechat-title="$route.meta.title"> | ||||
| 			<Header></Header> | ||||
| 			<router-view></router-view> | ||||
| 			<Footer></Footer> | ||||
| 		</div> | ||||
| 	</n-config-provider> | ||||
|   </n-message-provider> | ||||
| 
 | ||||
| </template> | ||||
| 
 | ||||
| <style> | ||||
| .txt-1 { | ||||
|   overflow: hidden; | ||||
| 
 | ||||
| </style> | ||||
|   white-space: nowrap; | ||||
| 
 | ||||
|   text-overflow: ellipsis; | ||||
| 
 | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -1,12 +1,21 @@ | ||||
| import http from './request'; | ||||
| 
 | ||||
| export function getXXX() { | ||||
| 	return http('/api/get'); | ||||
| export function getPolitics(params) { | ||||
| 	return http('/api/politics/politics', { | ||||
| 		method: 'GET', | ||||
| 		params: params, | ||||
| 	}); | ||||
| } | ||||
| 
 | ||||
| export function postXXX(params) { | ||||
| 	return http('/api/post', { | ||||
| export function getNewsbx(params) { | ||||
| 	return http('/api/newsbx/group', { | ||||
| 		method: 'POST', | ||||
| 		params: params, | ||||
| 	}); | ||||
| } | ||||
| } | ||||
| export function getNewsbxList(params) { | ||||
| 	return http('/api/newsbx/index', { | ||||
| 		method: 'POST', | ||||
| 		params: params, | ||||
| 	}); | ||||
| } | ||||
|  | ||||
| @ -3,7 +3,7 @@ import axios from 'axios'; | ||||
| // 创建新的axios实例
 | ||||
| const service = axios.create({ | ||||
| 	// 环境变量,需要在.env文件中配置
 | ||||
| 	baseURL: 'http://wz.lytv.com.cn/', | ||||
| 	baseURL: '/api', | ||||
| 	// 超时时间暂定5s
 | ||||
| 	timeout: 5000, | ||||
| }); | ||||
| @ -77,4 +77,4 @@ service.interceptors.response.use( | ||||
| 		return Promise.resolve(error.response); | ||||
| 	} | ||||
| ); | ||||
| export default Request; | ||||
| export default Request; | ||||
|  | ||||
							
								
								
									
										
											BIN
										
									
								
								src/assets/img/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/img/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 12 KiB | 
							
								
								
									
										
											BIN
										
									
								
								src/assets/img/qrcode1.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								src/assets/img/qrcode1.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 24 KiB | 
| @ -1,6 +1,24 @@ | ||||
| <template> | ||||
| 	<div> | ||||
| 		************** | ||||
| 	<div style="width: 100%;background-color: #0051B1"> | ||||
|     <div style="padding:0px 9rem;color: #FFFFFF"> | ||||
|       <div style="padding: 50px 0px;"> | ||||
|         <n-flex justify="space-between"> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|           <div>河南人民政府</div> | ||||
|         </n-flex> | ||||
|       </div> | ||||
|       <div style="height: 2px;opacity: 0.12;background: #FFFFFF;"></div> | ||||
|       <div style="text-align: center;padding: 60px 0px;"> | ||||
|         <div>洛阳中网 豫ICP备05020961号 \ 豫公网安备 41031102000159 信息网络传播视听节目许可证(AVSP)编号:1608331</div> | ||||
|         <div style="margin: 10px 0px;">网络举报电话:0379-63353039 网络举报邮箱:lytvzhwzh@163.com</div> | ||||
|         <div>声明:本网部分内容来源于互联网,如有侵权内容请及时与网站管理员联系及时删除处理!</div> | ||||
|       </div> | ||||
|     </div> | ||||
| 	</div> | ||||
| </template> | ||||
| 
 | ||||
| @ -8,4 +26,4 @@ | ||||
| </script> | ||||
| 
 | ||||
| <style> | ||||
| </style> | ||||
| </style> | ||||
|  | ||||
| @ -1,24 +1,28 @@ | ||||
| <template> | ||||
| 
 | ||||
| 
 | ||||
| 	<div style="background-color: #EFEFEF;width: 100%;"> | ||||
| 		<div style="padding: 0rem 8rem;color: #A1A1A1;font-size: 0.75rem;height: 2.125rem;line-height: 2.125rem;"> | ||||
| 		<div style="padding: 0rem 9rem;color: #A1A1A1;font-size: 0.75rem;height: 2.125rem;line-height: 2.125rem;"> | ||||
| 			<n-flex justify="space-between"> | ||||
| 				<div>您好,欢迎来到洛阳百姓问政!</div> | ||||
| 				<div> | ||||
| 					请<span style="color:#7B83FF">「登录」</span>或<span style="color:#7B83FF">「注册」 忘记密码</span> | ||||
| 					请<span style="color:#7B83FF">「登录」</span>或<span style="color:#7B83FF">「注册」</span> | ||||
| 				</div> | ||||
| 			</n-flex> | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div class="b1-back"> | ||||
| 		<div style="padding:0rem 0 0 7.7rem;font-weight: 600;"> | ||||
| 			<div style="font-size: 2.5rem;color: #FFFFFF;;">洛阳百姓问政</div> | ||||
| 			<div style="font-size: 1.19rem;color: #FFFFFF;letter-spacing: 0.6rem;margin-top: -0.9rem;"> | ||||
| 				wz.lytv.com.cn | ||||
| 			</div> | ||||
| 		<div style="padding:0rem 0 0 9rem;font-weight: 600;"> | ||||
| 			<div> | ||||
|         <div style="font-size: 2.5rem;color: #FFFFFF;;">洛阳百姓问政</div> | ||||
|         <div style="font-size: 1.19rem;color: #FFFFFF;letter-spacing: 0.52rem;margin-top: -0.9rem;"> | ||||
|           wz.lytv.com.cn | ||||
|         </div> | ||||
|       </div> | ||||
|       <div style="position: absolute;text-align: center;top: 25px;left: 405px"> | ||||
|         <img src="/src/assets/img/logo.png" style="width: 45px"> | ||||
|         <div style="color: #FFFFFF;font-size: 12px">洛阳广播电视台</div> | ||||
|       </div> | ||||
| 		</div> | ||||
| 		<div style="font-weight: 600;padding:7.7rem; 0 0 0.6"> | ||||
| 		<div style="font-weight: 600;padding:9rem; 0 0 0.6"> | ||||
| 			<n-input-group> | ||||
| 				<n-input placeholder="请输入想找的问题" style="width: 17rem;" /> | ||||
| 				<n-flex :size="[1,0]"> | ||||
| @ -38,7 +42,7 @@ | ||||
| 		</div> | ||||
| 	</div> | ||||
| 	<div style="padding: 5px 0px;"> | ||||
| 		<n-flex justify="center" align="center" :size="[146,10]"> | ||||
| 		<n-flex justify="center" align="center" :size="[141,10]"> | ||||
| 			<div class="left-line"></div> | ||||
| 			<n-button text color="#0051B1"> | ||||
| 				<template #default> | ||||
| @ -77,11 +81,17 @@ | ||||
| </template> | ||||
| 
 | ||||
| <script setup lang="ts"> | ||||
| import {ref, reactive, onMounted} from 'vue' | ||||
| 	import { ButtonProps } from 'naive-ui' | ||||
| 	type ButtonThemeOverrides = NonNullable<ButtonProps['themeOverrides']> | ||||
| 	const buttonThemeOverrides : ButtonThemeOverrides = { | ||||
| 		borderRadius: '0px' | ||||
| 	} | ||||
| onMounted(() => { | ||||
|   window.sessionStorage.setItem('user',JSON.stringify({'name':'测试'})); | ||||
|   var item=window.sessionStorage.getItem('user'); | ||||
|   console.log(item); | ||||
| }) | ||||
| </script> | ||||
| 
 | ||||
| <style scoped> | ||||
| @ -107,4 +117,4 @@ | ||||
| 		height: 6.25rem; | ||||
| 		background: url('../assets/img/b1.png') no-repeat; | ||||
| 	} | ||||
| </style> | ||||
| </style> | ||||
|  | ||||
| @ -9,10 +9,10 @@ const router = createRouter({ | ||||
| 	routes: [{ | ||||
| 		path: "/", | ||||
| 		meta: { | ||||
| 			title: '首页' //title配置
 | ||||
| 			title: '洛阳百姓问政-首页' //title配置
 | ||||
| 		}, | ||||
| 		component: () => import("../view/home/index.vue") | ||||
| 	}], | ||||
| }); | ||||
| 
 | ||||
| export default router | ||||
| export default router | ||||
|  | ||||
| @ -1,198 +1,331 @@ | ||||
| <template> | ||||
| 	<div> | ||||
| 		<div style="padding:20px 8rem ;"> | ||||
| 			<div><img src="@/assets/img/b2.png" style="width: 100%;" /></div> | ||||
| 			<div | ||||
| 				style="text-align: center;position: relative;margin-top: 1.25rem;padding-top: 1.125rem;height: 3.75rem;"> | ||||
| 				<img src="@/assets/img/bz1.png" style="width: 40%;" /> | ||||
| 				<div | ||||
| 					style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;top: 0;font-size: 2.5rem;letter-spacing: 5px;"> | ||||
| 					最新问政</div> | ||||
| 				<div | ||||
| 					style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;bottom: 0;font-size: 0.875rem;letter-spacing: 0.0625rem;"> | ||||
| 					ZUI XIN WEN ZHENG</div> | ||||
| 
 | ||||
| 			</div> | ||||
| 			<div style="margin-top: 20px;"> | ||||
| 				<n-flex justify="center" :size="[50,0]"> | ||||
| 					<div style="font-size: 1.25rem;color: #0051B1;font-weight: 600;">最新问政</div> | ||||
| 					<div style="font-size: 1.25rem;">最新回复</div> | ||||
| 				</n-flex> | ||||
| 			</div> | ||||
| 			<div style="margin-top: 20px;"> | ||||
| 				<n-flex justify="center" :size="[0,0]"> | ||||
| 					<div style="width: 50%;"> | ||||
| 						<n-table striped> | ||||
| 							<thead> | ||||
| 								<tr> | ||||
| 									<th width="100px">编号</th> | ||||
| 									<th>问政</th> | ||||
| 									<th>部门</th> | ||||
| 									<th>状态</th> | ||||
| 									<th>评论</th> | ||||
| 								</tr> | ||||
| 							</thead> | ||||
| 							<tbody> | ||||
| 								<tr> | ||||
| 									<td> | ||||
| 										110 | ||||
| 									</td> | ||||
| 									<td> | ||||
| 										<div class="dian1"> | ||||
| 											政和路午桥华府A区这段…政和路午桥华府A区这段…政和路午桥华府A区这段…政和路午桥华府A区这段…政和路午桥华府A区这段…政和路午桥华府A区这段… | ||||
| 										</div> | ||||
| 									</td> | ||||
| 									<td>彻底废除</td> | ||||
| 									<td>...</td> | ||||
| 									<td>干!我刚才背的是啥</td> | ||||
| 								</tr> | ||||
| 							</tbody> | ||||
| 						</n-table> | ||||
| 					</div> | ||||
| 					<div style="width: 50%;"> | ||||
| 						<n-table striped> | ||||
| 							<thead> | ||||
| 								<tr> | ||||
| 									<th>Abandon</th> | ||||
| 									<th>Abnormal</th> | ||||
| 									<th>Abolish</th> | ||||
| 									<th>...</th> | ||||
| 									<th>万事开头难</th> | ||||
| 								</tr> | ||||
| 							</thead> | ||||
| 							<tbody> | ||||
| 								<tr> | ||||
| 									<td>放弃</td> | ||||
| 									<td>反常的</td> | ||||
| 									<td>彻底废除</td> | ||||
| 									<td>...</td> | ||||
| 									<td>干!我刚才背的是啥</td> | ||||
| 								</tr> | ||||
| 							</tbody> | ||||
| 						</n-table> | ||||
| 					</div> | ||||
| 				</n-flex> | ||||
| 				<div class="register-form " style="text-align: center;margin-top: 1.25rem;"> | ||||
| 					<n-flex justify="center"> | ||||
| 						<n-pagination :theme-overrides="PaginationThemeOverrides" v-model:page="page" :page-count="100" | ||||
| 							size="medium" show-quick-jumper show-size-picker | ||||
| 							:page-sizes="[{ label: '10条/页',value: 10}]"> | ||||
| 							<template #goto> | ||||
| 								跳转 | ||||
| 							</template> | ||||
| 						</n-pagination> | ||||
| 					</n-flex> | ||||
| 				</div> | ||||
| 			</div> | ||||
| 			<div style="margin-top: 30px;"> | ||||
| 				<n-flex justify="center" :size="[145,0]"> | ||||
| 					<div style="position: relative;"> | ||||
| 						<img src="@/assets/img/zu1.png" style="width: 300px;" /> | ||||
| 						<div | ||||
| 							style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
| 							我要投诉 | ||||
| 						</div> | ||||
| 					</div> | ||||
| 					<div style="position: relative;"> | ||||
| 						<img src="@/assets/img/zu2.png" style="width: 300px;" /> | ||||
| 						<div | ||||
| 							style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
| 							公共服务 | ||||
| 						</div> | ||||
| 					</div> | ||||
| 					<div style="position: relative;"> | ||||
| 						<img src="@/assets/img/zu3.png" style="width: 300px;" /> | ||||
| 						<div | ||||
| 							style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
| 							问政部门 | ||||
| 						</div> | ||||
| 					</div> | ||||
| 					<div style="position: relative;"> | ||||
| 						<img src="@/assets/img/zu4.png" style="width: 300px;" /> | ||||
| 						<div | ||||
| 							style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
| 							问政热榜 | ||||
| 						</div> | ||||
| 					</div> | ||||
| 				</n-flex> | ||||
| 			</div> | ||||
|   <div> | ||||
|     <div style="padding:20px 9rem ;"> | ||||
|       <div><img src="@/assets/img/b2.png" style="width: 100%;"/></div> | ||||
|       <div | ||||
|           style="text-align: center;position: relative;margin-top: 10px;padding-top: 1.125rem;height: 3.75rem;"> | ||||
|         <img src="@/assets/img/bz1.png" style="width: 40%;" /> | ||||
|           style="text-align: center;position: relative;margin-top: 1.25rem;padding-top: 1.125rem;height: 3.75rem;"> | ||||
|         <img src="@/assets/img/bz1.png" style="width: 40%;"/> | ||||
|         <div | ||||
|             style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;top: 0;font-size: 2.5rem;letter-spacing: 5px;"> | ||||
|           新闻推荐</div> | ||||
|           最新问政 | ||||
|         </div> | ||||
|         <div | ||||
|             style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;bottom: 0;font-size: 0.875rem;letter-spacing: 0.0625rem;"> | ||||
|           XIN WEN TUI JIAN</div> | ||||
|           ZUI XIN WEN ZHENG | ||||
|         </div> | ||||
| 
 | ||||
|       </div> | ||||
|       <div> | ||||
|         <n-flex justify="space-between"> | ||||
|          <div style=""> | ||||
|            <n-carousel draggable> | ||||
|              <img | ||||
|                  class="carousel-img" | ||||
|                  src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel1.jpeg" | ||||
|              > | ||||
|              <img | ||||
|                  class="carousel-img" | ||||
|                  src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel2.jpeg" | ||||
|              > | ||||
|              <img | ||||
|                  class="carousel-img" | ||||
|                  src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel3.jpeg" | ||||
|              > | ||||
|              <img | ||||
|                  class="carousel-img" | ||||
|                  src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel4.jpeg" | ||||
|              > | ||||
|            </n-carousel> | ||||
|          </div> | ||||
|           <div>123</div> | ||||
|       <div style="margin-top: 20px;"> | ||||
|         <n-flex justify="center" :size="[50,0]"> | ||||
|           <div @click="contneSelect(0)" :style="{ fontSize: '1.25rem', color: contnetKey === 0 ? '#0051B1' : '#000000', cursor: 'pointer' }">最新问政</div> | ||||
|           <div @click="contneSelect(1)" :style="{ fontSize: '1.25rem', color: contnetKey === 1 ? '#0051B1' : '#000000', cursor: 'pointer' }">最新回复</div> | ||||
|         </n-flex> | ||||
|       </div> | ||||
| 		</div> | ||||
| 	</div> | ||||
|       <div style="margin-top: 20px;"> | ||||
|         <n-flex justify="center" :size="[0,0]"> | ||||
|           <div style="width: 50%;"> | ||||
|             <n-table striped> | ||||
|               <thead> | ||||
|               <tr> | ||||
|                 <th width="100px">编号</th> | ||||
|                 <th>问政</th> | ||||
|                 <th>部门</th> | ||||
|                 <th>状态</th> | ||||
|                 <th>评论</th> | ||||
|               </tr> | ||||
|               </thead> | ||||
|               <tbody> | ||||
|               <tr v-for="(item,index) in contentList[0]"> | ||||
|                 <td> | ||||
|                   <div style="color:#606060;">{{item.id}}</div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div class="dian1"> | ||||
|                     {{item.politics_title}} | ||||
|                   </div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div style="color: #616161">{{item.department_name}}</div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div style="color: #0051B1"> | ||||
|                     <span v-if="item.acceptance_status==0">待处理</span> | ||||
|                     <span v-if="item.acceptance_status==1">已回复</span> | ||||
|                   </div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div>{{item.comment_count}}</div> | ||||
|                 </td> | ||||
|               </tr> | ||||
|               </tbody> | ||||
|             </n-table> | ||||
|           </div> | ||||
|           <div style="width: 50%;"> | ||||
|             <n-table striped> | ||||
|               <thead> | ||||
|               <tr> | ||||
|                 <th width="100px">编号</th> | ||||
|                 <th>问政</th> | ||||
|                 <th>部门</th> | ||||
|                 <th>状态</th> | ||||
|                 <th>评论</th> | ||||
|               </tr> | ||||
|               </thead> | ||||
|               <tbody> | ||||
|               <tr v-for="(item,index) in contentList[1]"> | ||||
|                 <td> | ||||
|                   <div style="color:#606060;">{{item.id}}</div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div class="dian1"> | ||||
|                     {{item.politics_title}} | ||||
|                   </div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div style="color: #616161">{{item.department_name}}</div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div style="color: #0051B1"> | ||||
|                     <span v-if="item.acceptance_status==0">待处理</span> | ||||
|                     <span v-if="item.acceptance_status==1">已回复</span> | ||||
|                   </div> | ||||
|                 </td> | ||||
|                 <td> | ||||
|                   <div>{{item.comment_count}}</div> | ||||
|                 </td> | ||||
|               </tr> | ||||
|               </tbody> | ||||
|             </n-table> | ||||
|           </div> | ||||
|         </n-flex> | ||||
|         <div class="register-form " style="text-align: center;margin-top: 1.25rem;"> | ||||
|           <n-flex justify="center"> | ||||
|             <n-pagination @update:page="pageCheck" :theme-overrides="PaginationThemeOverrides" v-model:page="page" :page-count="pageCount" | ||||
|                           size="medium" show-quick-jumper show-size-picker | ||||
|                           :page-sizes="[{ label: '10条/页',value: 10}]"> | ||||
|               <template #goto> | ||||
|                 跳转 | ||||
|               </template> | ||||
|             </n-pagination> | ||||
|           </n-flex> | ||||
|         </div> | ||||
|       </div> | ||||
|       <div style="margin-top: 30px;"> | ||||
|         <n-flex justify="center" :size="[135,0]"> | ||||
|           <div style="cursor: pointer;position: relative;"> | ||||
|             <img src="@/assets/img/zu1.png" style="width: 300px;"/> | ||||
|             <div | ||||
|                 style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
|               我要投诉 | ||||
|             </div> | ||||
|           </div> | ||||
|           <div style="cursor: pointer;position: relative;"> | ||||
|             <img src="@/assets/img/zu2.png" style="width: 300px;"/> | ||||
|             <div | ||||
|                 style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
|               公共服务 | ||||
|             </div> | ||||
|           </div> | ||||
|           <div style="cursor: pointer;position: relative;"> | ||||
|             <img src="@/assets/img/zu3.png" style="width: 300px;"/> | ||||
|             <div | ||||
|                 style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
|               问政部门 | ||||
|             </div> | ||||
|           </div> | ||||
|           <div style="cursor: pointer;position: relative;"> | ||||
|             <img src="@/assets/img/zu4.png" style="width: 300px;"/> | ||||
|             <div | ||||
|                 style="position: absolute;right: 20px;font-size: 2.5rem;color: #ffffff;top: 13px;font-weight: 600;"> | ||||
|               问政热榜 | ||||
|             </div> | ||||
|           </div> | ||||
|         </n-flex> | ||||
|       </div> | ||||
|       <div | ||||
|           style="text-align: center;position: relative;margin-top: 10px;padding-top: 1.125rem;height: 3.75rem;"> | ||||
|         <img src="@/assets/img/bz1.png" style="width: 40%;"/> | ||||
|         <div | ||||
|             style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;top: 0;font-size: 2.5rem;letter-spacing: 5px;"> | ||||
|           新闻推荐 | ||||
|         </div> | ||||
|         <div | ||||
|             style="color: #0051B1;position: absolute;margin: 0 auto;left: 0;right: 0;bottom: 0;font-size: 0.875rem;letter-spacing: 0.0625rem;"> | ||||
|           XIN WEN TUI JIAN | ||||
|         </div> | ||||
| 
 | ||||
|       </div> | ||||
|       <div style="margin-top: 20px"> | ||||
|         <n-flex justify="space-between"> | ||||
|           <div style="width: 50%"> | ||||
|             <n-carousel draggable :autoplay="true"> | ||||
|               <img | ||||
|                   class="carousel-img" | ||||
|                   src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel1.jpeg" | ||||
|               > | ||||
|               <img | ||||
|                   class="carousel-img" | ||||
|                   src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel2.jpeg" | ||||
|               > | ||||
|               <img | ||||
|                   class="carousel-img" | ||||
|                   src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel3.jpeg" | ||||
|               > | ||||
|               <img | ||||
|                   class="carousel-img" | ||||
|                   src="https://naive-ui.oss-cn-beijing.aliyuncs.com/carousel-img/carousel4.jpeg" | ||||
|               > | ||||
|             </n-carousel> | ||||
|           </div> | ||||
|           <div style="width: 48%"> | ||||
|             <n-flex justify="space-between"> | ||||
|               <div  v-for="(item, index) in groupList" @click="openGroup(item.id)" :class="{ 'int': true, 'act': item.id == groupIndex }">{{item.name}}</div> | ||||
|             </n-flex> | ||||
|             <div style="padding: 2.5px 0px;margin-top: 20px" v-for="(item,index) in groupNews"> | ||||
|               <n-flex justify="space-between"> | ||||
|                 <div class="txt-1" style="font-size: 17px;width: 70%"> | ||||
|                   <div style="background-color: #0051B1;width: 5px;height: 5px;border-radius: 50%;display: inline-block;vertical-align: middle"></div> | ||||
|                   <text style="vertical-align: middle;margin-left: 5px">{{item.news_title}}</text> | ||||
|                 </div> | ||||
|                 <div style="color: #818794">{{item.showtime}}</div> | ||||
|               </n-flex> | ||||
|             </div> | ||||
|           </div> | ||||
|         </n-flex> | ||||
|       </div> | ||||
|     </div> | ||||
|   </div> | ||||
|   <div style="background: #D9D9D9;width: 120px;height: 180px;text-align: center;padding: 5px 0px 10px 0px;position: fixed;top: 50%;left: 10px"> | ||||
|     <div style="text-align: right;padding-right: 5px"> | ||||
|       <svg style="width: 20px;height: 20px;color: #999797" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 512 512"><path d="M256 48C141.31 48 48 141.31 48 256s93.31 208 208 208s208-93.31 208-208S370.69 48 256 48zm86.63 272L320 342.63l-64-64l-64 64L169.37 320l64-64l-64-64L192 169.37l64 64l64-64L342.63 192l-64 64z" fill="currentColor"></path></svg> | ||||
|     </div> | ||||
|     <div style="color: #0051B1;font-size: 12px">洛阳百姓问政</div> | ||||
|     <div style="color: #0051B1;font-size: 12px">公众号</div> | ||||
|     <div> | ||||
|       <img src="@/assets/img/qrcode1.png" style="width: 100px;height: 100px;margin-top: 10px"> | ||||
|     </div> | ||||
|   </div> | ||||
|   <div style="background: #D9D9D9;width: 120px;height: 180px;text-align: center;padding: 5px 0px 10px 0px;position: fixed;top: 50%;right: 10px"> | ||||
|     <div style="text-align: right;padding-right: 5px"> | ||||
|       <svg style="width: 20px;height: 20px;color: #999797" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 512 512"><path d="M256 48C141.31 48 48 141.31 48 256s93.31 208 208 208s208-93.31 208-208S370.69 48 256 48zm86.63 272L320 342.63l-64-64l-64 64L169.37 320l64-64l-64-64L192 169.37l64 64l64-64L342.63 192l-64 64z" fill="currentColor"></path></svg> | ||||
|     </div> | ||||
|     <div style="color: #0051B1;font-size: 12px">洛阳百姓问政</div> | ||||
|     <div style="color: #0051B1;font-size: 12px">公众号</div> | ||||
|     <div> | ||||
|       <img src="@/assets/img/qrcode1.png" style="width: 100px;height: 100px;margin-top: 10px"> | ||||
|     </div> | ||||
|   </div> | ||||
| </template> | ||||
| 
 | ||||
| <script setup lang="ts"> | ||||
| 	import { PaginationProps } from 'naive-ui' | ||||
| 	import { | ||||
| 		ref | ||||
| 	} from 'vue'; | ||||
| 	const page = ref(1); | ||||
| 	type PaginationThemeOverrides = NonNullable<PaginationProps['themeOverrides']> | ||||
| 	const PaginationThemeOverrides : PaginationThemeOverrides = { | ||||
| 		"itemTextColorHover": "#0051B1", | ||||
| 		"itemTextColorPressed": "#0051B1", | ||||
| 		"itemTextColorActive": "#ffffff", | ||||
| 		"itemBorderActive": "1px solid #0051B1", | ||||
| 		"itemColorActive": "#0051B1", | ||||
| 		"itemColor": "#F5F5F5", | ||||
| 		"itemColorActiveHover": "#0051B1" | ||||
| 	} | ||||
| import {PaginationProps,useMessage } from 'naive-ui' | ||||
| import {getPolitics,getNewsbx,getNewsbxList} from "@/api/index"; | ||||
| import {ref, reactive, onMounted} from 'vue' | ||||
| const message = useMessage() | ||||
| const page = ref(1); | ||||
| const pageCount=ref(1); | ||||
| const contentList=ref([]); | ||||
| const contnetKey=ref(0); | ||||
| const groupList=ref([]); | ||||
| const groupIndex=ref(0); | ||||
| const groupNews=ref([]); | ||||
| onMounted(() => { | ||||
|   getApiPolitics(); | ||||
|   getApiNewsbx(); | ||||
| }) | ||||
| const getApiPolitics = () => { | ||||
|   getPolitics({'type':contnetKey.value,'page':page.value,'pageSize':10}).then(res => { | ||||
|     if(res.code==200){ | ||||
|       contentList.value=chunk(res.data,2); | ||||
|       pageCount.value=Math.ceil(res.count / 10); | ||||
|       }else{ | ||||
|       message.error(res.msg) | ||||
|     } | ||||
|   }); | ||||
| } | ||||
| const getApiNewsbx = () => { | ||||
|   getNewsbx({'flag':'index'}).then(res => { | ||||
|     if(res.code==200){ | ||||
|       groupList.value=res.data; | ||||
|       groupIndex.value=res.data[0].id; | ||||
|       getApiNewsList(res.data[0].id); | ||||
|     }else{ | ||||
|       message.error(res.msg) | ||||
|     } | ||||
|   }); | ||||
| } | ||||
| const getApiNewsList = (gory_id) => { | ||||
|   getNewsbxList({'gory_id':gory_id,'page':1,'pageSize':7}).then(res => { | ||||
|     if(res.code==200){ | ||||
|       groupNews.value=res.data; | ||||
|     }else{ | ||||
|       message.error(res.msg) | ||||
|     } | ||||
|   }); | ||||
| } | ||||
| const openGroup = (index) => { | ||||
|   groupIndex.value=index; | ||||
|   getApiNewsList(index); | ||||
| } | ||||
| const pageCheck = (p) => { | ||||
|     console.log(p); | ||||
|   page.value=p; | ||||
|   getApiPolitics(); | ||||
| } | ||||
| const contneSelect = (type) => { | ||||
|   contnetKey.value=type; | ||||
|   page.value=1; | ||||
|   getApiPolitics(); | ||||
| } | ||||
| const chunk = (arr, size) => { | ||||
|   const firstChunkSize = Math.ceil(arr.length / 2); | ||||
|   const firstChunk = arr.slice(0, firstChunkSize); | ||||
|   const secondChunk = arr.slice(firstChunkSize); | ||||
|   return [firstChunk, secondChunk]; | ||||
| }; | ||||
| type PaginationThemeOverrides = NonNullable<PaginationProps['themeOverrides']> | ||||
| const PaginationThemeOverrides: PaginationThemeOverrides = { | ||||
|   "itemTextColorHover": "#0051B1", | ||||
|   "itemTextColorPressed": "#0051B1", | ||||
|   "itemTextColorActive": "#ffffff", | ||||
|   "itemBorderActive": "1px solid #0051B1", | ||||
|   "itemColorActive": "#0051B1", | ||||
|   "itemColor": "#F5F5F5", | ||||
|   "itemColorActiveHover": "#0051B1" | ||||
| } | ||||
| </script> | ||||
| 
 | ||||
| <style scoped lang="scss"> | ||||
| .int{ | ||||
|   font-size: 20px; | ||||
|   cursor: pointer; | ||||
| } | ||||
| .act{ | ||||
|   color: #0051B1; | ||||
|   font-weight: 600; | ||||
| } | ||||
| .carousel-img { | ||||
|   width: 50%; | ||||
|   height: 240px; | ||||
|   width: 100%; | ||||
|   height: 400px; | ||||
|   object-fit: cover; | ||||
| } | ||||
| 	.n-table { | ||||
| 		border-radius: 0px; | ||||
| 		width: 100%; | ||||
| 	} | ||||
| 
 | ||||
| 	.n-table thead tr th { | ||||
| 		font-size: 1.2rem; | ||||
| 	} | ||||
| .n-table { | ||||
|   border-radius: 0px; | ||||
|   width: 100%; | ||||
| } | ||||
| 
 | ||||
| 	.dian1 { | ||||
| 		width: 8.75rem; | ||||
| 		white-space: nowrap; | ||||
| 		overflow: hidden; | ||||
| 		text-overflow: ellipsis; | ||||
| 	} | ||||
| .n-table thead tr th { | ||||
|   font-size: 1.2rem; | ||||
| } | ||||
| 
 | ||||
| .dian1 { | ||||
|   font-size: 16px; | ||||
|   color: #0051B1; | ||||
|   width: 8.75rem; | ||||
|   white-space: nowrap; | ||||
|   overflow: hidden; | ||||
|   text-overflow: ellipsis; | ||||
|   cursor: pointer; | ||||
| } | ||||
| </style> | ||||
|  | ||||
| @ -7,10 +7,23 @@ import path from "path" | ||||
| // https://vitejs.dev/config/
 | ||||
| export default defineConfig({ | ||||
| 	plugins: [vue()], | ||||
| 	server: { | ||||
| 		port: 5000, | ||||
| 		proxy: { | ||||
| 			'/api': { | ||||
| 				target: 'http://wz.lytv.com.cn/', | ||||
| 				// target就是你要访问的目标地址,可以是基础地址,这样方便在这个网站的其他api口调用数据
 | ||||
| 				ws: true, | ||||
| 				changeOrigin: true, | ||||
| 				rewrite: (path) => path.replace(/^\/api/, '') | ||||
| 				// 要记得加rewrite这句
 | ||||
| 			}, | ||||
| 		}, | ||||
| 	}, | ||||
| 	resolve: { | ||||
| 		// Vite路径别名配置
 | ||||
| 		alias: { | ||||
| 			'@': path.resolve('./src') | ||||
| 		} | ||||
| 	} | ||||
| }) | ||||
| }) | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user