# 时间
现在已经 2022 年 5 月 10 日 09:57:02 了,提交作品是 20 号,虽然网页早已完成,但是 PPT 还没有动,所以这篇博客主要就来思考一下 PPT 要写什么,如何去介绍这个网页,这个网页用到了什么技术,为什么要做这个网页,围绕这几点,看看能不能想出一大堆文字,这样我滴任务就完成了。
询问了老师的意见,PPT 的作用就是用来介绍网页和队友的,所以使用博客来介绍网页性质是一样的,因为我的审美实在是太差啦,所以我还是使用博客来讲解此网页吧,毕竟我的话比较多,如果做 ppt,文字太多实际上是非常不美观的。
# 起因
我来蓝色技术工作室已经三个学期了,即使当上了团支书,也没有为这里做过什么很有意义的事情,能参加的比赛也是少之又少,拿不出什么成绩,感觉这个社团要凉凉了,但是硬件那边能参加的比赛很多,所以一直支撑这我们,为了这个社团,软件这里也需要多参加活动,保持活跃度,让大家都认识到这里是干什么滴,就这样想着开始从零开始,先参加学院的比赛打磨自己,就有了这个网页,其实还有很多滴原因。
比如软件这边展示的东西很少,也就是没有,大部分同学都是后端,只能写一写接口,这样怎么能拿出去展示,机械就不一样了,能做出许多好玩的东东,航模,智能车,3D 打印。相比软件,唯一能展示的只有网页了,所以刚学完 vue 的我准备自己写一个小小小的项目来巩固一下自己的知识,就想出了这个宣传网站,这样纳新的时候也许就可以展示这个拉夸的网页,让大家都清楚这个社团是干什么的,能为自己带来什么,这也许就是为什么诞生了这个拉夸的网页的原因~~
其实真正的原因就是... 胃痛患者参加了上学期学院的移动开发设计拿了二等奖领了一个雷蛇鼠标,我也想要!!!这才是主要原因,但是我总不能说我是想要鼠标和键盘才来参加比赛的吧,所以我只能说是,因为软件队能展示的东西只有网页,不然宣传社团的时候东西全是硬件队,软件队就会毫无存在感,好像两个都很重要,所以为了这些,我才有动力去完成这个网页,虽然没花几天,实际上我一两天就可以完成,毕竟功能不多,设计拉夸,毫无美感,但依旧是我的First Vue Web
# PPT
讲了许多没用的废话,现在可以开始思考一下如何去介绍网页了,为了不浪费大家的时间来看这个拉夸的网页,所以我准备 PPT 和网页以及代码同时讲,能讲的东西不算多,所以放在一起更好。
# SPA 单页面应用程序
开始之前肯定要介绍一下 SPA 单页面应用程序 然后演示一下 SPA 与其他网页的区别
什么是单页面应用程序
单页面应用程序 (英文名:Single Page Application)简称 SPA,指的就是一个 Web 网站中只有唯一一个 HTML 页面,所有的功能和交互都在这唯一的一个页面内完成单页面应用程序的特点
单页面应用程序将所有的功能局限于一个 web 页面中。仅在该 web 页面初始化时加载相应的资源(HTML,JavaScript,CSS)
一旦页面加载完成,SPA 不会因为用户的操作而进行页面的重新加载或跳转。而是利用 JavaScript 动态的变换 HTML 内容,从而实现用户的交互。
单页应用程序的优点
良好的交互体验
- 单页面应用的内容的改变不需要重新加载整个页面
- 获取数据也是通过 Ajax 异步获取
- 没有页面之间的跳转,所以不会出现 “白屏现象”
良好的前后端工作分离模式
- 后端专注于提供 API 接口,更容易实现 API 接口的附庸
- 前端专注于页面的渲染,更利于前端工程化的发展
减轻服务器的压力
- 服务器只需提供数据,不负责页面的合成与逻辑的处理,吞吐能力会提高几倍。
单页应用程序的缺点
- 首屏加载慢
- 不利于 SEO
文字太多懒得看,用几句话总结就是:SPA 非常好用,所有的功能和交互都在这唯一的一个页面内完成,跳转到其他页面不会刷新,但不管什么东西都是有缺点的,如果页面较大,那么开始加载网页的时候就会比较慢,即使是这样也可以通过懒加载来解决这个问题,也就是需要的时候加载,不需要的时候不加载。
# 组件库
作品使用了这两个组件库,有了这两个组件库给我带来了许多的帮助,所以为什么说两天就能做好了,
- Vant 轻量、可靠的移动端 Vue 组件库
- Element Ui 一套为开发者、设计师和产品经理准备的基于 Vue 2.0 的桌面端组件库
# 首页
刚进入页面的时候可以看到 Element Ui 中的对话框,提示同学疫情注意安全和配合学校工作。
使用了 Vant 组件中的 NavBar 导航栏,Swipe 轮播。
- 其中在 NavBar 导航栏中,使用作用域插槽把蓝色技术工作室的图标嵌入进去,并加了一个点击事件,也就是返回上一级。
即使是有组件库也无法满足,所以封装了一个活动组件,由于宣传页面不需要过多的数据,所以模拟后台发送 ajax 数据 通过
v-for
来循环渲染和传参。点击卡片后可以跳转到相对应的页面。
✔️伪数据
ActivityList: [ | |
{ | |
img: 'https://i.ibb.co/v3CPzDj/Active-img-01.jpg', | |
font_title: '江西科技学院第四届轮式机器人竞速', | |
font_content: '为了加强我校大学生软硬件知识学习,提高实际运算能力,蓝色技术开始进行江西科技学院第四届轮式机器人竞速赛,比赛于2021年11月29日在J8-101举行', | |
type_font: '竞赛', | |
time: '2021.12.13' | |
}, | |
{ | |
img: 'https://i.ibb.co/4gJTyf0/1.jpg', | |
font_title: '蓝色技术工作室冬至饺子宴', | |
font_content: '时遇冬至,新加入工作室的小伙伴们已经开始融入这个集体,为了给大伙在忙碌之余增添些色彩,蓝色技术工作室特举办了一场盛大的饺子宴', | |
type_font: '活动', | |
time: '2021.12.22' | |
}, | |
{ | |
img: 'https://www.weihaisheng.com/wp-content/uploads/2021/12/2021-768x512.jpg', | |
font_title: '蓝色技术工作室年度总结', | |
font_content: '新年的到来是对过往的检讨对未来的期望,2021已去对过去的一年,总要有句结束语跟着零碎的图片共同回忆惆怅的2021', | |
type_font: '总结', | |
time: '2022.1.1' | |
}, | |
] |
✔️v-for 循环渲染与传参
<Activity | |
v-for="(item,index) in ActivityList" | |
:key="index" | |
:time="item.time" | |
:active_img="item.img" | |
:font_title="item.font_title" | |
:font_content="item.font_content" | |
:active_type="item.type_font" | |
@click.native="Hop_routing(index)"> | |
</Activity> |
# 活动页
- 点击左上角的图标即可返回上一个页面
this.$router.go(-1);
- 当然,在右上角的菜单中也有返回上一级的按钮,使用了 Vant 和 Element Ui 中的抽屉和单元格
# robot
只有这个页面使用了 ajax 来请求数据
使用 v-model
与 input 表单相互绑定,然后绑定按钮,点击触发后发送 ajax 数据,并渲染页面
// 发送 | |
async send() { | |
if (this.ipt_text.trim() === '') { | |
this.ipt_text = '' | |
return Toast.fail('输入内容为空'); | |
return | |
} | |
let text = this.ipt_text | |
$(".talk_list").append(` <li class="right_word"> | |
<img style="width: 40px;height: 40px;border-radius: 50%" src="" /> | |
<span>${text}</span> | |
</li>`); | |
this.ipt_text = '' | |
this.myList = text; | |
const {data: res} = await axios.get('http://www.liulongbin.top:3006/api/robot', { | |
params: {spoken: text} | |
}) | |
// 清除 输入框内容 | |
let robot = res.data.info.text; | |
$(".talk_list").append(` <li class="left_word"> | |
<img style="width: 40px;height: 40px;border-radius: 50%" src="https://jxut-bst.github.io/uploads/avatar.png" /> | |
<span>${robot}</span> | |
</li>`); | |
// console.log(res) | |
}, |
考虑到 PC 端,按下回车键也可以触发按钮
如果技术扎实,完全可以把对话框封装成组件来使用,但是使用了 jquery 来渲染页面
$(".talk_list").append(` <li class="left_word"> | |
<img style="width: 40px;height: 40px;border-radius: 50%" src="https://jxut-bst.github.io/uploads/avatar.png" /> | |
<span>${robot}</span> | |
</li>`); |
# 好队友
队员 | 性别 | 班级 | 所做的事 |
---|---|---|---|
李昊 | 男 | 20 专软件 4 班 | 页面布局与样式,编写博客介绍此网页 |
于佳琦 | 女 | 20 本计算机 5 班 | 提供相关图片,编写文案,提供样式建议 |
宁楠 | 男 | 21 专软件 5 班 | 提供伪后台代码与机器人接口 |