结对第二次作业——编程实现

062100143郑恩琦 2024-09-30 23:53:19
这个作业属于哪个课程FZU_SE_teacherW_4
这个作业要求在哪里结对第二次作业——编程实现-CSDN社区
结对学号172109032,062100143
这个作业的目标了解前端知识,学习Vue
其他参考文献《构建之法》

@[toc]

基本要求

仓库链接 代码规范链接 云服务器链接

仓库地址 云服务器链接

功能分析

1. 系统设计

1.1 模块化设计

该网站应采用模块化设计,将不同的功能模块进行独立开发和维护。主要模块包括:

  • 赛事日程模块:展示比赛日程、赛程安排和比赛结果。

  • 奖牌榜模块:实时更新各国奖牌数,包括金银铜奖牌的分布。

  • 足球对阵模块:展示足球比赛的结果信息。

  • 首页模块:提供最新的赛事新闻、亮点回顾等。

1.2 系统架构

  • 前端:前端部分可以采用基于 Vue.js 的单页面应用程序(SPA)架构,确保页面的动态更新速度快,用户体验流畅。结合 Element UI 提供一致性高、视觉美观的界面。

2. 系统合理性分析

2.1 可扩展性

模块化设计允许后期功能扩展和升级变得更加简单。例如,系统可以随时新增一个新的互动模块或数据分析模块,而不影响现有功能的运行。确保系统能长期运行和适应未来需求。

2.2 用户体验

用户体验设计方面通过 SPA 和缓存机制,确保页面加载速度快,交互流畅,使用简单易懂。此外,提供个性化的推荐系统、多语言支持、以及各类互动功能,确保全球用户无障碍访问,并提升参与感。

模型设计

开发工具

Vue

设计过程

img

  • 确认需求,决定功能接口

  • 设计网页由几个部分组成。

  • 具现化每个页面,并且链接关系

结果汇报

设计思路

首页

首页支持四个标题跳转

img

同时制作了奥运海报,新闻快讯,以及联系方式等信息。

img

奖牌榜

可滑动奖牌榜,拥有全面的国家获奖信息

img

竞赛日程

每日项目

img

实现日期跳转

img

比赛的对阵双方以及结果

img 查看出赛名单

img

切换查看详情

img

 

足球对阵

足球对阵图,同时鼠标移入呈现动效

img 点击观看相关赛事视频

img

 

代码说明

首页跳转实现

 <div >
         <div class="div1">
             <div class="div2">
                 <button class="btn1">
                     <router-link to="/home_page">首页</router-link>
                 </button>
                 <button class="btn1">
                     <router-link to="/medal_list">奖牌</router-link>
                 </button>
                 <button class="btn1">
                     <router-link to="/everyday_game">赛况</router-link>
                 </button>
                 <button class="btn1">
                     <router-link to="/football_battle">足球</router-link>
                 </button>
             </div>
         </div>
     
    .................................
     
 <style>    
 .btn1 {
     background-color: #fff; /* 白色背景 */
     border: none; /* 无边框 */
     border-radius: 50%; /* 圆形按钮 */
     width: 50px; /* 按钮宽度 */
     height: 50px; /* 按钮高度 */
     cursor: pointer; /* 鼠标悬停时显示手形光标 */
     margin-right: 15px; /* 右边距 */
 }
 </style> 
 ​

将文字写于按钮中,用router-link方法来实现页面跳转

首页新闻快讯部分

 </div>
         <h2 style="font-size: 1.8rem;margin-left: 10px;">新闻快讯</h2>
         <hr style="margin: 5px;">
         <div style="display: flex;">
             <div class="div5">
                 <h2 style="color: aliceblue;">回顾 Léon Mar 奥运会</h2>
             </div>
 ​
             <div>
 ​
                 <img src="https://img.olympics.com/images/image/private/t_16-9_640/f_auto/primary/oiby8xfrjsvvrzhj05iz"
                     width="500px">
                 <h2>您最喜欢的运动员和团队的表现如何?</h2>
             </div>
 ​
         </div>
 ​
         <div style="display: flex; margin-top: 20px;">
             <div style="display: flex; margin-left: 20px;">
                 <img src="https://img.olympics.com/images/image/private/t_1-1_85/f_auto/primary/nqa5embksmb9hujkjlw1">
                 <h3 style="margin-left: 10px;">
                     Les JO de Paris 2024 avaient tout pour eux : Sports
                     <br>
                     激情比赛
                 </h3>
             </div>
             <div style="display: flex; margin-left: 20px;">
                 <img src="https://img.olympics.com/images/image/private/t_1-1_85/f_auto/primary/rz2kkqo2urreowmpnfg0">
                 <h3 style="margin-left: 10px;">
                     Sites iconiques, Parc des Champions, cérémonie
                     <br>
                     热烈巴黎
                 </h3>
             </div>
             <div style="display: flex; margin-left: 20px;">
                 <img src="https://img.olympics.com/images/image/private/t_1-1_85/f_auto/primary/sz5uhgfeojam4rpy2ooe">
                 <h3 style="margin-left: 10px;">
                     Pauline Ferrand-Prévot | Replay
                     <br>
                     疯狂一夏
                 </h3>
             </div>
         </div>

巧妙地应用flex等样式,通过调整margin-left和right等参数控制图片的相对布局

奖牌榜所有国家排名实现

         <div  v-for="(country,index) in countries" :key="index" style="display: block;unicode-bidi: isolate;">
             <div style="display: flex;;width: 862px;height: 56px;margin: 0 auto;box-sizing: border-box;border: 1px solid #ddd;margin-top: 10px;padding: 0 20px;">
                 <p  style="margin-right: 40px; width: 17.76px;">{{ country.index }}</p>
                 <img  :src="countries[index].img" style="width: 30px;height: 20px;position: relative;top: 4px;margin-right: 10px;margin-top: 15px;">
                 <p  style="margin-right: 150px; width: 176px;">{{ country.name }}</p>
                 <p  style="color: rgb(102, 102, 102); margin-right: 70px; width: 17.76px;">{{country.gold}}</p>
                 <p  style="color: rgb(102, 102, 102); margin-right: 70px; width: 17.76px;">{{ country.sliver }}</p>
                 <p  style="color: rgb(102, 102, 102); margin-right: 70px; width: 17.76px;">{{country.brozen}}</p>
                 <p  style="margin-right: 50px; width: 26.65px;">{{country.total}}</p>
                 <button style="margin-top: 10px; width: 32px;height: 32px;background-color: #fff;border: 1px solid #999;border-radius: 5px;">
                     <img src="https://gstatic.olympics.com/s1/t_original/static/srm/paris-2024/expand.svg" width="24" height="24" style="position: relative;right: 3px;top: 3px;">
                 </button>
             </div>
         </div>
 ​
 ....................................
 <script>
 import axios from 'axios';
 ​
 export default {
     data(){
         return{
             countries:[]       
         }
     },
     methods: {
         
     },
     mounted(){
         axios.get("data/img.json").then((result) => {
             this.countries = result.data.data;
         }).catch((err) => {
             alert(err + "数据传输失败");
         });
     }
 }
 </script>

通过抓包先爬取网页数据处理成img.json文件

然后外层容器用v-for循环遍历countries数组生成多个div

内层容器,使用 flex 布局,将元素横向排列,然后获取国家的具体信息

日期选择器

          <!-- 日期选择器栏,阴影效果和居中对齐 -->
         <div style="height: 72px; width: 100%; box-shadow: 0 5px 5px #eee;">
             <div style="width: 896px; height: 100%; margin: 0 auto; box-sizing: border-box; padding: 16px; display: flex; justify-content: end; align-items: center;">
                 <!-- 使用 Element UI 中的日期选择器组件 -->
                 <el-date-picker v-model="value1" type="date" placeholder="选择日期" value-format="M-dd" :picker-options="dataRange">
                 </el-date-picker>
             </div>
         </div>
 ​
         <!-- 选择日期后的显示栏,背景色为蓝色,居中对齐 -->
         <div style="width: 1200px; height: 100px; margin: 0 auto; background-color: rgb(167, 192, 242); margin-bottom: 40px; margin-top: 30px; display: flex; justify-content: center; align-items: center;">
             <p style="color: #fff; font-size: 40px; margin: 0">{{ value1 }}</p>
         </div>
 ​
 ​
 ​
 ​
 <script>
 import axios from 'axios';
 ​
 export default {
 ​
     data() {
         return {
             althes:[],
             value1: "7-24",
             dataRange:{
                 disabledDate(time){
                     return new Date(time).getTime() < new Date('2024-07-23').getTime() || new Date(time).getTime() > new Date('2024-08-12').getTime();
                 }
             }
         }
     },
     methods(){
 ​
     },
     mounted(){
         axios.get("data/7-24.json").then((result) => {
             this.althes = result.data.data;
         }).catch((err) => {
             alert(err + "数据传输失败");
         });
     },
     updated(){
         axios.get("data/"+this.value1+".json").then((result) => {
             this.althes = result.data.data;
         }).catch((err) => {
             alert(err + "数据传输失败");
         });
     }
 ​
 }
 </script>

用Element UI 中的日期选择器组件 value-format定义了日期格式picker-options 限制可选日期范围,

并且将选择日期后的显示栏变蓝,字体变白。

用updated()函数监听 value1 的更新,当日期更改时重新获取对应日期的数据

比赛详细信息

 <!-- 比赛信息的循环展示-->
         <div v-for="(player,index) in althes" :key="index" style="display: block; width: 1000px; height: 220px; margin: 0 auto;">
             <div style="width: 100%; border: 2px solid rgba(0, 0, 0, .6); border-radius: 10px; cursor: pointer; margin-bottom: 20px;">
                 <div style="width: 100%; height: 80px; box-sizing: border-box; display: flex;">
                     <div style="width: 100px; height: 100%; display: flex; justify-content: center; align-items: center; border-right: 2px solid rgba(0, 0, 0, .6); box-sizing: border-box;">
                         <p style="font-weight: 700; font-size: 20px;">{{player.time}}</p>
                     </div>
                      <!-- 如果比赛是足球 -->
                     <router-link to="/match_details" v-if="player.competitionName == '足球'" style="display:contents">
                         <div style="width: 200px; height: 100%; margin-left: 30px; box-sizing: border-box; padding-top: 5px; display:contents">
                             <p style="font-size: 25px; font-weight: 900; margin-left: 25px;">{{player.competitionName}}</p>
                             <p style="font-size: 15px; margin-top: 35px; margin-left: 22px;">{{player.competitionInfo}}</p>
                         </div>
                     </router-link>
 ​
                     <!-- 如果比赛不是足球 -->
                     <div v-else style="width: 200px; height: 100%; margin-left: 30px; box-sizing: border-box; padding-top: 5px; display:contents">
                         <p style="font-size: 25px; font-weight: 900; margin-left: 25px;">{{player.competitionName}}</p>
                         <p style="font-size: 15px; margin-top: 35px; margin-left: 22px;">{{player.competitionInfo}}</p>
                     </div>
                 </div>
 ​
                 <!-- 比赛下半部分 -->
                 <div style="border-top: 2px solid rgba(0, 0, 0, .6); width: 100%; min-height: 100px;">
                     <!-- 第一支国家队信息,显示国旗、国家名称和比分 -->
                     <div style="width: 100%; height: 50px; display: flex; align-items: center; box-sizing: border-box; padding-left: 120px; position: relative;">
                         <span v-if="althes[index].countryImg1 != null"><img :src="althes[index].countryImg1" style="width: 31.6px; height: 21.6px;"></span>
                         <span v-else><img src="https://gstatic.olympics.com/s1/t_original/static/noc/oly/3x2/180x120/EOR.png" style="width: 31.6px; height: 21.6px;"></span>
                         <p style="margin-left: 15px;">{{player.countryName1}}</p>
                         <p style="position: absolute; right: 20px; font-weight: 900;">{{ player.countryScore1 }}</p>
                     </div>
 ​
                     <!-- 第二支国家队信息,布局同上 -->
                     <div style="width: 100%; height: 50px; display: flex; align-items: center; box-sizing: border-box; padding-left: 120px; position: relative;">
                         <span v-if="althes[index].countryImg2 != null"><img :src="althes[index].countryImg2" style="width: 31.6px; height: 21.6px;"></span>
                         <span v-else><img src="https://gstatic.olympics.com/s1/t_original/static/noc/oly/3x2/180x120/EOR.png" style="width: 31.6px; height: 21.6px;"></span>
                         <p style="margin-left: 15px;">{{player.countryName2}}</p>
                         <p style="position: absolute; right: 20px; font-weight: 900;">{{ player.countryScore2 }}</p>
                     </div>
                 </div>
             </div>

遍历 althes 数组中的每个比赛项目,每个比赛的外层容器,包含比赛时间、比赛名称和比赛国家等信息

然后 如果比赛是足球,则使用 router-link 跳转到比赛详情页 ,如果比赛不是足球,直接展示比赛名称和信息,不跳转。

比赛下半部分,展示国家和比分。 ###

 <router-link :to="{ path: '/match_details', query:{'date':value1,'s1':score1,'s2':score2} }" v-if="player.competitionName=='足球'" style="display:contents">
                         <div style="width: 200px;height: 100%;margin-left: 30px;box-sizing: border-box;padding-top: 5px;display:contents">
                             <p style="font-size: 25px;font-weight: 900;margin-left: 25px;">{{player.competitionName}}</p>
                             <p style="font-size: 15px;margin-top: 35px;margin-left: 22px;">{{player.competitionInfo}}</p>
                         </div>
                     </router-link>

在页面跳转时传递数据,实现页面关联

遇到的困难及解决方法

困难描述

  1. 日期选择器难以制作

  2. 足球对阵放大缩小会改变相对布局

  3. 如何实现按钮的跳转 4.如何传递信息在不同页面

解决尝试+是否解决

  1. A:通过搜索引擎得知 用 Element UI 可以方便快速实现 。

  2. A:在设置组件位置时不能将位置信息设置为absolute(绝对),而是要相对的

  3. A: 通过B站视频得知要用到router-link 4.可以使用query传递,拿this.$route.query接收

有何收获

前端的知识非常错综复杂,还需要更多的学习体验。

组队总结

结对感受

此次编程任务较为艰巨,

队友评价

zc to zeq 各尽其能,各司所职 zeq to zc 很强,被带飞了

合作截图

敲定项目合作及分工

img

img 确认进度

img

 

PSP表格

PSPProcess Stages预估耗时实际耗时
Planning计划分钟分钟
• Estimate• 估计这个任务需要多少时间1010
• Analysis• 需求分析 (包括学习新技术)300300
• Design Spec• 生成设计文档2020
• Design• 具体实现400600
• Test• 测试(自我测试,修改界面,提交修改)6060
Reporting报告6060
 合计8501050
 
  
  
  
  

@[toc]

基本要求

仓库链接和代码规范链接

仓库地址 代码规范地址

原型网页

原型网址

NABCD模型

N(Need,需求) 巴黎奥林匹克运动会第33届夏季奥林匹克运动会,我们希望能设计一个平台,通过图表等形式来直观显示选手信息、正式赛每日结果等。平台应满足客户以下需求: 必要需求

  • 更加直观显示客户所需比赛信息

  • 快速查找切换比赛赛事信息

  • 呈现信息更加具体,无需综合多个页面才能得到所需信息

辅助需求

  • 在总奖牌页面显示各运动奖牌

  • 比赛链接

  • 主页

需求象限图外围功能杀手功能
必要需求和大家一样,制作排名界面更好更炫酷的页面切换效果
辅助需求维持不做

我们解决了之前的使用文字来显示,不够直观、具体,对用户不够友好等痛点。

A(Approach,做法) 对于Approach,在原型设计方面,我们需要做到的是:

  1. 了解如何直观呈现原型界面的技术

  2. 更好描述原型各个阶段需求的知识,如需求图制作所需知识

  3. 动态修改原型的纠错优化系统的开发知识

B(Benefit,好处) 相对于别的界面设计,我们需要做到如下要求:

  • 简洁美丽的UI界面

  • 呈现信息更详细

  • 详细比赛回放链接

C(Competitors,竞争)

img

D(Delivery,推广) 在汇报阶段推广,在CSDN发表博文。

模型设计

开发工具

Vue

设计过程

img

  • 确认需求,决定功能接口

  • 设计网页由几个部分组成。

  • 具现化每个页面,并且链接关系

结果汇报

设计思路

首页

首页2

首页

首页支持四个标题跳转,同时制作了奥运海报,新闻快讯,以及联系方式等信息。

奖牌榜

奖牌

可滑动奖牌榜,拥有全面的国家获奖信息

每日赛程

 

足球对阵

 

代码说明

 

遇到的困难及解决方法

困难描述

  1. 排行榜如何实现滑动演示

  2. 鼠标移入移出如何实现动效切换

  3. 如何处理组件覆盖优先级问题

解决尝试+是否解决

  1. A:在哔哩哔哩搜索组件怎么实现滑动,最终不采用组件状态变化,而使用滑动组件直接达到滑动效果

  2. A:研究了会组件,发现组件可以设置动效切换,新建事件成功解决。

  3. A: 右键设置顶部或底部

有何收获

多摸索摸索其实原型设计并不难,难的反而是审美设计。

组队总结

结对感受

此次编程任务较为艰巨,

队友评价

zc to zeq

zeq to zc

 

合作截图

确认开工时间

img

确认合作分工及如何制作

img

img 优化修改

img

 

效能分析

使用墨刀同时协作,可以直接看到同伴在做什么,这样有助于及时修改。花费时间的反而是寻找素材,确认审美。

PSP表格

PSPProcess Stages预估耗时实际耗时
Planning计划分钟分钟
• Estimate• 估计这个任务需要多少时间1010
• Analysis• 需求分析 (包括学习新技术)300300
• Design Spec• 生成设计文档2020
• Design• 具体实现400600
• Test• 测试(自我测试,修改界面,提交修改)6060
Reporting报告6060
 合计8501050
...全文
43 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
AJAX——新手快车道 前言 AJAX是什么? 首先、AJAX是一种很酷的技术,一旦采用了AJAX,就能让你的Web页面, 你的网站,甚至连同你们公司,都变得很酷。在Web2.0的时代里,不使用一点 AJAX技术的网站,就会显得很老土,很落伍。 但是,这样的理解,其实是很肤浅的。仅仅是从一个外行,从一个使用者的 角度出发,来理解AJAX,就像我在本书的第一章AJAX我也行中那样,开发 出很愚蠢,甚至都没有资格被称之为AJAX应用的纯IE、XMLHTTP应用。 AJAX更酷的一点在于,对于传统的Web开发人员来说,AJAX所运用的, 是更加先进的,更加标准化的,更加和谐高效的,完整的Web开发技术体系。 遵循这样的体系开发Web应用,能让你的开发过程变得更加轻松,也能使你们 的开发团队,显得很酷。在Web2.0 的时代里,还在采用过时的技术来开发 Web,会显得很老土,很落伍。 AJAX的相关组成技术,每一个都已经出现了N年以上了,对这些技术的 组合运用,也远远早于AJAX这个名词出现之前。所以,我真正敬佩的,并非提 出 AJAX这个缩写的Jesse James Garrett。而是那些早在N年以前,就已经在探索、 实践的先行者,他们始终在追求的:是更好的用户体验,以及更好的开发体验。 这样的精神,才是最可宝贵的,也是最值得我们学习的。许多年过去以后,当我 们再回头来看当年的这些热门技术,也许早已经变得老土,变得落伍了。在这样 的历程中,哪些人会成长为高手?会成长为大师呢?就是那些永不满足,永远 在追求更好的用户体验,永远在追求更好的开发体验的人! 新手如何上路 软件开发这个领域,永远都在飞速发展,大家都必须不断的学习新的知识、 技能、框架、IDE、甚至新的语言。传说中的骨灰级高手们,就像传说中的大侠, 任何武器、哪怕是一块木头到了他们手里,也能发挥惊人的威力,人家练了几十 年的看家本领,他们随手使来,也竟然像是打娘胎里就开始练了一样。为什么? 就算不吹那么玄的,平常我们能够碰到的那些老手,在学新东西的时候, 也比那些新手学得更快,理解得更深,运用得更熟练。而新手们呢?往往就会漫 无头绪,焦头烂额,以一副张着茫然的大眼睛的经典表情,出现在各大论坛的 新手求助区里。他们欠缺的,究竟是什么呢?为什么老手学新东西,就没遇到那 么多困难呢? 泛泛地说,自然是经验上的欠缺。仔细地说来,又可以分为三个方面: 一、本质,一种技术与另一种技术之间,往往会有本质上的相通之处,当你 对一种技术的理解与思考越来越深入时,学习一种新技术也会更加容易。触类旁 通,举一反三的能力,就是来自于对于技术本质的追寻。 二、地图,本质上或多或少的相通,也提示着我们技术之间的相互关联,当 你了解的技术越多,了解得越是深入,在你的内心,就能建立起越发清晰的技 术地图。各种知识都有一个自然、合理的位置。那么当一个老手要学习一门新技术 的时候,他其实并非在探索一个全新的、未知的领域,而是有很多脉络可寻,也 很多已知可以帮助他们快速了解未知。 三、技巧,面对同样的未知,面对同样的难题,新手们一筹莫展,而老手们 却掌握着更多的技巧和手段,帮助他们试探可能性、缩小问题的范围、迅速定位 问题、不犯明显愚蠢的错误、甚至能够列举出更具命中力的搜索关键词,而这些 技巧,都帮助老手在前进的道路上,更少跌倒,即使跌倒,也能更快的爬起来。 作为一本写给新手的入门书籍,我们希望展现给读者的,是一个老手如何 学习新技术的过程。我们相信,这样的一个学习过程,对于新手来说,是更具有 价值的。 何谓快车道 必须老老实实的承认,我吹牛了!老手虽然会比新手学习得更快一些,但 是也同样会碰到麻烦,遇到障碍,感觉头痛。如果没有真正的专家的指导,我不 可能如此迅速地将AJAX掌握到目前这样的程度,要真是让我自学三个月,然 后就写出书来的话,那真是在骗钱了。 老手能够快速学习的另一个重要的诀窍是:认识很多牛人朋友 如果没有李锟与赵泽欣的专家级指导与帮助,如果没有与李锟AJAX结对 编程的体验,如果没有三个人在MSN上无数次的长聊,我想要在短期内建立起: 对于AJAX本质的理解; 对于整个AJAX以及相关技术地图的理解; 对于AJAX编程开发所需要的很多技巧、手段的掌握; 几乎是不可能的。 如果没有(N多需要感谢的人)的(N多方面的帮助),我们这本书,也 不可能以现在这样的深度,以(N个月)内完成的速度,送到读者的面前。 希望这本书,能够对大家快速学习AJAX,有所帮助。

110

社区成员

发帖
与我相关
我的任务
社区管理员
  • FZU_SE_teacherW
  • 助教赖晋松
  • D's Honey
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧