在线考试前端

Michael Wang 61d1bffa37 添加 CHANGELOG.md 6 ani în urmă
docs 3ec2f85e65 规范文档管理 6 ani în urmă
public 0e182f43a9 update dependencies & format 6 ani în urmă
src 39651f1481 add iview 6 ani în urmă
tests d5f4bcfa83 init 6 ani în urmă
.browserslistrc d5f4bcfa83 init 6 ani în urmă
.eslintrc.js d5f4bcfa83 init 6 ani în urmă
.gitignore d5f4bcfa83 init 6 ani în urmă
CHANGELOG.md 61d1bffa37 添加 CHANGELOG.md 6 ani în urmă
README.md 39651f1481 add iview 6 ani în urmă
babel.config.js 39651f1481 add iview 6 ani în urmă
jest.config.js d5f4bcfa83 init 6 ani în urmă
package.json a952f05284 规划发版计划 6 ani în urmă
postcss.config.js d5f4bcfa83 init 6 ani în urmă
yarn.lock 6f364fed02 update vue 6 ani în urmă

README.md

介绍

本项目是作为公司的前端的模板项目。采用的是 Vue 的全家桶技术。

本文档介绍项目如何使用和扩展、采用的技术栈、目录结构和最佳实践等。你不用一次看完所有内容,但是建议在正式开发前完整读一遍文档。

安装、启动和打包

安装:

yarn

启动:

npm start

打包:

npm run build

技术栈

Vue 2.x Vuex 3.x Vue router 2.x

TODO: 架构图

构建工具

vue-cli

工具安装

Chrome 插件

Vue.js devtools

VS Code 插件

  1. Vetur (Author: Pine Wu)
  2. Prettier (Author: Esben Petersen) # 注意: 其他的 vscode 插件可能导致格式化不一致
  3. REST Client (Author: Huachao Mao)
  4. Quokka.js (Author: Wallaby.js) - optional

目录结构

目录 说明
build/ 打包产出
config/ 打包配置文件
node_modules/ 依赖包
src/assets/ 图片、字体文件等文件. 在多数情况下,应该把资源文件放在 src/features/下,这种情况可以让应用垂直划分,同时可以更干净的删除资源。
src/auth/ 认证信息是全局的
src/components/ 全局组件 
src/constants/ 集中放置全局  常量,方便更新 API 的服务器地址等
src/directives/ 全局的 directive
src/features/ 实现业务需求的组件。目标是让尽可能多的相关文件在相同的业务组件内。这使得开发团队可以更好的划分任务。业务组件可以依赖全局元素,如 src/auth, src/components, src/directives,或者依赖其它业务组件。但是业务组件不应该依赖其它业务组件的子组件,它应该使用其它组件的 public API。必要时,子组件可能在业务组件中重复。
src/http/ 包含非认证  的 HTTP 请求( 认证的部分应该在 src/auth 中做)。同时包含 router 和 routes。如果 routes 变的很大,可以将它拆分到 src/features 中,然后通过 import 引用。
src/store/ 使用 Vuex 管理状态的单一 store
src/styles/ 全局样式。 局部样式应该放在 src/features/中
src/utils/ 共享的工具类。 跟业务有关的  工具方法放在 src/features/中
static/ 不需要 Webpack 处理的静态文件
tests/ 单元测试和 E2E 测试

错误处理

通用的错误处理

API 请求

从用户操作,界面有一处集中显示操作反馈。
处理顺序如下:

  1. 用户操作
  2. 触发 vue action
  3. 调用 vuex action(无需处理错误)
  4. 调用 api,若出错,修改全局错误状态,并通知展示状态
  5. 界面展示程序状态,即出错信息

如果用户需要 vuex action 的结果,可以在 vuex action 里面返回 promise,不建议在 component 处理状态。 应该尽可能通过 store 的状态更新使得界面更新。

状态处理

无需共享状态的组件可以直接在组件的生命周期中发请求获取数据。一般是纯显示的组件比较多。

共享状态的通过 vuex 来处理。

TODO:

  1. module state
  2. 新项目以 ES2018 为基准,选择 stage 3 的特性,将常用的特性列表在 readme 中给出网址
  3. 目前(2019-01-31),iview 和 elementui 都已经明确表示它们不支持移动端(在移动端组件的显示不是很完美)。移动端的策略需要另外讨论。quasar vux vuetify
  4. animation 以 iview 内部为主。个别地方需要定制的话,可以自制动画,或采用 animated.js
  5. iview 处理 less 的主题修改有问题 github issue 考虑通过单独的项目来定制主题 iview docs

参考资料

  1. Vue-pizza
  2. Error handling with async-await in Vue and Vuex