摘自Berwin《Vue项目架构设计与工程化实践》github.com/berwin/Blog/issues/14

1.Vue依赖套件

vuex:项目复杂后,用vuex来管理状态

element-ui:基于vue2.0的组件库

vue-router:单页面应用必须使用的前端路由

axios:vue官方推荐的http客户端

vue-cli:webpack模板,功能全。有hot reload,linting,testing,css extraction等

2.整体架构设计

表现层: Store Router View Component

业务层: 服务(Service)

API层: 接口API Mock + Validator

Util层: Util

基础设施层:init(初始化配置文件) dev(开发环境) deploy(编译源码,静态文件上传cdn,Hera发步上线)

3.目录结构

|——README.md

|——build #build脚本

|——config #prod/dev build config等文件

|——hera #代码发布上线

|——index.html #最基础的网页

|——package.json

|——src #Vue.js核心业务

| |——App.vue #App Root Component

| |——api #接入后端服务的基础API

| |——assets #静态文件

| |——components #组件

| |——event-bus #Event Bus事件总线,类似EventEmitter

| |——main.js #Vue入口文件

| |——router #路由

| |——service #服务

| |——store #Vuex状态管理

| |——util #通用utility,derective,mixin还有绑定到Vue.prototype的函数

| |——view #各个页面

|——static #DevServer静态文件

|——test #测试

4.模块

表现层:

store Vuex状态管理

router 前端路由

view 各业务页面

component 通用组件

业务层:

service 处理服务端返回的数据(类似data format)例如service同时调用了不同的api,把不同的返回数据整合在一起发送到store中

API层:

api 请求数据,Mock数据,反向校验后端api

Util层

util 存放项目全局的工具函数

... 如果项目需要,可写一些vue指令

基础设施层

init 自动化初始化配置文件

dev 启动dev-server,hot-reload,http-proxy等辅助开发

deploy 编译源码,静态文件上传cdn,生成html,发布上线

全局事件机制

event-bus 主要用来处理特殊需求

5.特殊场景

1>在router中拿不到vue实例,无法直接操作vuex的方法,此时采用event-bus

2>生存周期不同步问题:event-bus的生存周期是全局的,只有在页面刷新的时候,event-bus才会重置内部状态,而组件的声明周期相对来说短了很多

6.登录功能逻辑

client          ——请求数据——>       server
<——返回未登录错误码—— ——>跳转 登录中心
<——sid ——请求数据(携带sid)——>
<——返回数据 + 种cookie—— ——请求数据(携带cookie)——>
<—— 返回数据 ——
1>监听所有api的响应,如果未登录后端会返回一个错误码
2>如果后端返回

Vue项目架构设计与工程化实践的更多相关文章

  1. Vue 项目架构设计与工程化实践

    来源 文中会讲述我从0~1搭建一个前后端分离的vue项目详细过程 Feature: 一套很实用的架构设计 通过 cli 工具生成新项目 通过 cli 工具初始化配置文件 编译源码与自动上传CDN Mo ...

  2. 基于 Angularjs&Node.js 云编辑器架构设计及开发实践

    基于 Angularjs&Node.js 云编辑器架构设计及开发实践 一.产品背景 二.总体架构 1. 前端架构 a.前端层次 b.核心基础模块设计 c.业务模块设计 2. Node.js端设 ...

  3. 项目开发中的一些注意事项以及技巧总结 基于Repository模式设计项目架构—你可以参考的项目架构设计 Asp.Net Core中使用RSA加密 EF Core中的多对多映射如何实现? asp.net core下的如何给网站做安全设置 获取服务端https证书 Js异常捕获

    项目开发中的一些注意事项以及技巧总结   1.jquery采用ajax向后端请求时,MVC框架并不能返回View的数据,也就是一般我们使用View().PartialView()等,只能返回json以 ...

  4. no.2淘宝架构背后——零售业务中台架构设计探讨及实践读后感

    2017年8月12日,袋鼠云首席架构师正风在“网易博学实践日:大数据与人工智能技术大会”进行<淘宝架构演进背后——零售业务中台架构设计探讨及实践>演讲分享.传统零售行业如何选择应对新经济模 ...

  5. Vue 项目骨架屏注入与实践

    作为与用户联系最为密切的前端开发者,用户体验是最值得关注的问题.关于页面loading状态的展示,主流的主要有loading图和进度条两种.除此之外,越来越多的APP采用了“骨架屏”的方式去展示未加载 ...

  6. 基于Repository模式设计项目架构—你可以参考的项目架构设计

    关于Repository模式,直接百度查就可以了,其来源是<企业应用架构模式>.我们新建一个Infrastructure文件夹,这里就是基础设施部分,EF Core的上下文类以及Repos ...

  7. QingStor 对象存储架构设计及最佳实践

    对象存储概念及特性 在介绍 QingStor️对象存储内部的的架构和设计原理之前,我们首先来了解一下对象存储的概念,也就是从外部视角看,对象存储有什么特性,我们应该如何使用. 对象存储本质上是一款存储 ...

  8. Springboot项目架构设计

    导航 前言 流水线 架构的艺术 项目架构 理解阿里应用分层架构 superblog项目架构 结语 参考 本节是<Spring Boot 实战纪实>的第7篇,感谢您的阅读,预计阅读时长3mi ...

  9. 企业架构设计之IFW实践回顾

    前言 笔者几年前曾参与过一套网络银行的系统建设以及后续这套系统在信用.云服务.保险.基金.支付等领域的复用,使用了IFW模型的变体.当时仅仅是根据架构师的设计进行编码.测试和交付以及后续的维护,没有对 ...

随机推荐

  1. AndroidStudio项目提交到github最详细步骤

    在使用studio开发的项目过程中有时候我们想将项目发布到github上,以前都是用一种比较麻烦的方式(cmd)进行提交,最近发现studio其实是自带这种功能的,终于可以摆脱命令行了. 因为自己也没 ...

  2. (转)linux passwd批量修改用户密码

    linux passwd批量修改用户密码  原文:http://blog.csdn.net/xuwuhao/article/details/46618913 对系统定期修改密码是一个很重要的安全常识, ...

  3. php表单提交时的身份证号码验证

    <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/ ...

  4. python标准输入

    备忘 #! /usr/bin/python2.6 import sys for line in sys.stdin: print line,

  5. mysql关闭严格模式

    通过配置文件修改: linux找my.cnf文件 window的修改办法是找my.ini sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES  ub ...

  6. SQL简单语句(增删改查)

    简单的SQL语句增删改查操作 说明: 在mysql里面亲测结果正确    用到的表(学生表:studnets) 1.创建一个学生表,(学号,姓名,性别,家庭住址) mysql> create t ...

  7. Dynamics CRM 2011通过客户端代码选择视图

    在实施的过程中我们经常会遇到这样的场景,有个系统标准的Lookup字段对应的不是一种Entity,如很多地方的客户实际上可选account或者contact,有的地方可选systemuser或者tea ...

  8. <Android 基础(十五)> Alert Dialog

    介绍 The AlertDialog class allows you to build a variety of dialog designs and is often the only dialo ...

  9. Android Studio使用OpenCV的配置方法

    1.下载 进入官网(http://opencv.org/)下载OpenCV4Android并解压.目录结构如下图所示. 其中,sdk目录即是我们开发opencv所需要的类库:samples目录中存放着 ...

  10. Jetty服务器的使用

    Jetty 是一个开源的servlet容器,它为基于Java的web容器,例如JSP和servlet提供运行环境.Jetty是使用Java语言编写的,它的API以一组JAR包的形式发布.开发人员可以将 ...