import{o as e,c as o,C as s,b as n,a,V as p,y as l}from"./chunks/framework.b31a4d00.js";const t=p(`
首先得有 Node.js,并确保 node 版本是 12.13 或以上。
# 打印 node 版本
node -v
v12.13.0
推荐使用 pnpm 管理 npm 依赖
# 全局安装 pnpm
npm i pnpm -g
这一章节会帮助你从头搭建一个简单的 Fes.js 前端应用。
如果工作空间不存在,则先创建:
# 创建目录 workspace
mkdir workspace
# 进入目录 workspace
cd workspace
如果工作空间已存在,则直接进入
# 进入目录 workspace
cd workspace
# 创建模板
pnpm create @fesjs/fes-app myapp
# 创建模板
npx @fesjs/create-fes-app myapp
如果项目文件夹 workspace/myapp
已经存在,会提示目录已存在:
你可以选默认适用于中后台前端应用的 PC
类型,也可以选适用于移动端的 H5
类型。
# 进入项目目录
cd myapp
# 安装依赖
pnpm i
# 进入项目目录
cd myapp
# 安装依赖
npm i
# 开发调试
pnpm dev
pnpm run v1.22.4
$ fes dev
Starting the development server http://localhost:8000 ...
✔ Webpack
Compiled successfully in 15.91s
DONE Compiled successfully in 15917ms 11:17:08 AM
# 开发调试
npm run dev
> fes dev
Starting the development server http://localhost:8000 ...
✔ Webpack
Compiled successfully in 3.66s
DONE Compiled successfully in 3662ms 11:17:46 AM
Fes.js 会在 http://localhost:8000
启动一个热重载的开发服务器。当你修改你的 .vue 文件时,浏览器中的内容也会自动更新。
# 构建
pnpm build
pnpm run v1.22.4
$ fes build
✔ Webpack
Compiled successfully in 45.37s
✨ Done in 48.87s.
# 构建
npm run build
> fes build
✔ Webpack
Compiled successfully in 45.37s
构建产物默认生成到 ./dist 下,然后通过 tree 命令查看。
tree ./dist
dist
├── chunk-vendors.27cd4686.js
├── chunk-vendors.a5f5de67.css
├── index.11411d43.css
├── index.d72f1ba2.js
├── index.html
├── logo.png
└── static
└── logo.0f85bba0.png
发布之前,可以通过 serve 做本地验证,验证结果应该跟执行 fes dev
的结果一样。
本地验证完,就可以部署了。你需要把 dist 目录部署到服务器上。
`,9),v=JSON.parse('{"title":"快速上手","description":"","frontmatter":{},"headers":[],"relativePath":"guide/getting-started.md"}'),u={name:"guide/getting-started.md"},_=Object.assign(u,{setup(m){return(A,g)=>(e(),o("div",null,[t,s("img",{src:n(l)("pickTemplateTip.png"),alt:"目录已存在提示"},null,8,c),r,i,s("p",null,[a("当选择 "),y,a(" 或者 "),d,a(" 或者项目目录 "),B,a(" 不存在,会提示选取一个 "),E,a(": "),s("img",{src:n(l)("pickTemplate.png"),alt:"选择模板类型"},null,8,h)]),D,s("img",{src:n(l)("home.png"),alt:"home"},null,8,C),b]))}});export{v as __pageData,_ as default};