项目开发

egg-vue-webpack-boilerplate 骨架项目中, 提供了一些demo, 如果要进行新项目开发,可以删除部分文件:

  • app/web/page 是页面目录。下面的每个目录都是一个单独的页面,其中 app 目录是一个单页面服务端渲染例子,其他是简单的 Vue 服务端渲染例子, 这些文件都可以删除,删除后,你需要自己按照类似方式添加页面进行开发。

  • app/controller 是服务端页面处理逻辑入口,下面都是例子,可以删除, 然后自己根据业务添加对应的controller

  • asset 是几个公共的静态资源文件,如果 app/web/component下面没有引用到,可以根据需要删除

  • controller 和 page 删除了部分文件后,需要清理 app/router.js 和 webpack.config.js 下面文件不存在的一下配置

  • app/web/component 下面的 app 是单页面的 router 配置,如果 app/web/page/app 删除了,这个也可以删除

  • app/web/component/layout 提供了单页面 layout 和 多页面 layout, 自己根据需要选用。

骨架模板

egg-vue-webpack-boilerplate 项目单独提供了两个纯净版本分支用于实际项目开发

命令配置

一般我们推荐把 easy build dev, easy build test, easy build prod 配置到 项目的 package.json 的 script 中去, 然后通过 npm run [command] 的方式使用。

  • 通过 npm run [command] 方式使用 easy 命令时,不需要全局安装 easywepback-cli 命令行工具, 只需要把 easywepback-cli 安装到项目 devDependencies 即可。

  • 在命令行直接使用 easy 命令时,需要全局安装 easywepback-cli 命令行工具。如果不安装, 可以通过 npm5 支持的 npx easy 方式运行。

{
   "scripts": {
    "clean": "easy clean",
    "debug": "egg-bin debug",
    "build": "cross-env easy clean && easy build prod",
    "dev": "egg-bin dev",
    "start": "egg-scripts start",
   }
}
  • 本项目本地开发过程中, npm run dev 自动启动 Webpack 内存构建,无需手动构建;

  • 测试环境和正式环境发布部署一定要先进行 npm run build 模式构建,然后再打包, 只用 npm start 启动即可

  • 如果不是用 egg-scripts start 启动应用, 请配置 EGG_SERVER_ENV 环境变量。EGG_SERVER_ENV表示 Egg 用那种方式启动, test 表示读取 config.test.js 配置, prod 表示读取 config.prod.js 配置, 正式线上运行一定要用 prod 模式。例如自己写 index.js 启动脚本, 然后通过 node index.js 启动时,请配置 EGG_SERVER_ENV 环境变量。

// ${root}/index.js
require('egg').startCluster({
  baseDir: __dirname,
  port: process.env.PORT
});

本地开发模式

npm run dev

使用 egg-webpack 插件进行前端资源构建, 这个插件只会在本地开发启用。

本地模拟测试环境

npm run build:test
npm run start:test

本地模拟正式环境

npm run build
npm start

打包部署

项目开发完成以后,我们要部署上线, 一般如下步骤:

清除缓存

npm run clean

开始构建

npm run build

打包上传

这里需要你自己实现把构建好的文件和项目文件一起打成 zip 或 tar 包,然后上传到部署平台进行部署。参数配置请见:https://easy-team.gitee.io/easywebpack/build

  • Node 端项目源代码需要打包上传,包括 config, app 目录 以及app/web/view(app/web 目录除外)

  • 需要把构建后的文件(public目录,app/view 目录, config/manifest.json)与 Node 端项目源代码一起打包部署,当然部分文件(README.md, eslint, gitignore等)可以不打进去。

  • 如果 node_modules 在打包时也打进去,packjson.json 里面的 devDependencies 依赖是不需要打进去的,这些只在开发期间和 Webpack 构建期间用到,不需要打进去。如果打进去也没有问题,只是包非常大,部署上传是个问题。

  • 如果 node_modules 在打包时不打进去,在启动之前,你需要先按照依赖 npm install --production

内置依赖和node依赖打包模式:

这里会把代码,构建文件,node_modules 以及 node 一起压缩程 zip, 这样线上在启动时就不需要安装依赖。

easy clean all
easy build prod
easy zip --deps --nodejs

线上安装依赖打包模式:

这里仅仅把代码构建文件一起压缩成 zip, 这样线上在启动时需要运行 npm install –production 安装依赖。

easy clean all
easy build prod
easy zip

线上项目启动

npm start

如果不是用 egg-scripts start 启动应用, 请配置 EGG_SERVER_ENV 环境变量 EGG_SERVER_ENV=prod NODE_ENV=production 配置环境变量.


Author: sky
Reprint policy: All articles in this blog are used except for special statements CC BY 4.0 reprint polocy. If reproduced, please indicate source sky !
 Previous
社区作品 社区作品
游戏中心小米游戏中心easy-team https://github.com/zhqlol/edgarserverhttps://www.jianshu.com/p/71fe6197d358https://github.com/MaleWeb/FullStack_Cli
2019-11-10 sky
Next 
服务端渲染模式 服务端渲染模式
Egg + Vue 服务端 Node 渲染模式目前 egg-view-vue-ssr 支持 服务端渲染模式 和 前端渲染模式 两种渲染模式这里服务端渲染指的是编写的 Vue 组件在 Node 服务端直接编译成完整的HTML, 然后直接输出给浏览器。MVVM 服务端渲染相比前端渲染,支持SEO,...
2019-11-10 sky