初衷
现如今社区上基于Vue
的项目已经多如牛毛了,为了提升自己对vue
的进一步理解,一直想找一个界面好看,功能完成的项目练练手。本人在逛各大招聘网站的时候发现了字节跳动
的官方招聘网站很适合自己练手。当我发现这个网站是由react
实现的,想了一下那我能不能用Vue
的技术栈完整的重构出来呢?
预览点 这里
数据从哪来?
一个完成的上线项目离不开完整的数据,那么我要做的这个项目真实数据要怎么才能拿到呢?于是自己又默默的打开了原版网站的开发者工具,在Network
面板里发现了浏览器请求到的官方API
接口。找到了API
接口就省心读了,问题是像字节跳动这样的公司对服务端API请求肯定会做跨域访问权限的限制,就算某一个接口能成功的请求到数据,对于一个想要长期作为自己项目访问的接口使用来说也是不稳定的。于是我又想到了接口代理的实现方案,大概的实现思路是使用express
搭建一个自己的服务器,包括项目上线后静态资源的托管都会用到。
服务端接口代理的小技巧
对于在浏览器端抓到的API
数据接口,纯粹的分析其地址和各种各样的参数无疑是很麻烦的一件事情,有没有一种办法可以一键复用它呢?答案是肯定的!由于node端没有原生的fetch
请求方法,这里需要借助一个第三方的node模块node-fetch
,这个是可以直接用npm安装的类似于浏览器端原生的fetch
请求模块。有了它我们在使用浏览器Network
面板里面的接口一键复制功能,具体操作请看下面的演示,详细的API代码案例请点击这里
此功能只有高版本的chrome 浏览器有此功能,如果您的浏览器没有此复制选项,请您升级到最新的浏览器后在使用
项目技术架构
为了进一步的提高自己的技术水平和更好的加深对Vue的理解,我选择了零代码开发所有的页面功能(没有使用任何第三方UI库)。
项目前端技术栈
- Vue 主框架
- vue-router 路由跳转的官方插件
- lodash 一个javascript的函数工具库
- axios 负责HTTP请求的插件
服务端技术栈
- express 搭建
web
服务器的nodejs
框架 - node-fetch 类似于浏览器端的fetch请求的polyfill
- connect-history-api-fallback 解决单页面应用程序在
history
模式下访问服务端出现404
的中间件
- express 搭建
项目开发工具
- vue-cli 快速搭建
Vue
工程的官方脚手架 - less
css
预处理器 - vscode 轻量的代码编辑器
- postman 测试调试
API
接口的工具 - vue-devtools
Vue
项目官方调试工具 - chrome 应用运行/调试环境
- git 开源版本控制系统
- vue-cli 快速搭建
部署环境
- 阿里云服务器线上地址 http://123.56.124.33:3000
- git远程仓库地址
git@github.com:konglingwen94/vue-bytedanceJob.git
- github 代码托管仓库https://github.com/konglingwen94/vue-bytedanceJob
项目源码目录
项目重要功能剖析
分页器组件 components/pagination.vue 查看源代码点这里
本人在开发这个分页器组件之前也是参考了多个网站的分页功能,各种各样的分页功能各不相同,挑选之后最终确定了自己比较认可的一个,此组件实现的功能如下图所示
从上图可以看出这是一个功能完成的分页器组件,基础性的代码这里就不过多的介绍了,具体实现点击这里。下面就主要分析一下在开发过程中遇到的难点!
当鼠标点击分页的数字按钮时,整个分页条会做相应的动态切换。当总页数超过一定的数值后,或者页面切换到某一个范围时会出现相应的省略号代替隐藏的页码数字展示。那这个功能逻辑应该怎么实现呢?
良好的思路是写出优雅代码的第一步,我把分页可能出现的状态分为四种情况
- 第一个省略号出现在最大页数前面时
- 分页条出现两个省略号时
- 省略号出现在最小页数后面时
- 分页器总页码小于默认展示的页码个数(分页条没有出现省略号)
根据以上列出的几种情况就可以使用代码去实现了,这里我使用Vue
的一个计算属性visiblePagers
进行了动态展示所有出现的页码,组件完整的代码如下
-
<
-
{{item}}
-
>
复选穿梭框组件 components/checkbox-transfer.vue 源代码地址
效果图
实现过程
对于这个组件功能的开发,我真的是煞费苦心,一言难尽。首先市面上没有一样的功能需求用例可供参考,其次在开发的过程中组件各种逻辑的实现也是在摸索着进行实现。在花费了一定时间仍没有较好的思路后,我默默的打开了世界上最大的程序员同性交友平台 github一番搜索,最终在开源项目基于Vue的组件库element-ui
中的transfer
组件中找到了可参考实现的逻辑实现方式。
重点逻辑分析
template
部分代码
{{title}}
-
-
{{ item[props.label] }}
对于这样一个交互复杂的复选穿梭框而言,定义好其基本的初始化数据状态是第一步要做的。对于此组件调用的时候,模板会传入一个属性名为data
(这里是一个数组)的props
选项作为组件的数据来源,接下来要关注的焦点就转移到了组件内部数据交互的各种实现方式上了。我首先在组件状态data
里面定义了一个名叫targets
的数组类型的变量用来存储默认展开的复选框列表项key
值,然后根据data
和targets
这两个基础数据状态又可以派生出两个计算属性sourceData
和targetData
用来分别渲染展开和隐藏起来的复选框选择项。至此组件基本的静态模板渲染的逻辑就构思完成了。相关部分代码如下
组件script
部分