v-island,vue3打造的ssg框架-01,初始化项目

前言

在学习掘金课程《基于 Vite 的 SSG 框架开发实战》过程中,看到课程的UI渲染是使用react,但本人更擅长vue,所以决定将react渲染UI改造成vue渲染,从而创建一个专栏,来记录整个过程。

ssg的概念及优劣点,建议大家购买课程观看,这里就不再赘述了。

1、初始化项目

创建文件夹v-island,本项目使用pnpm管理,进入到v-island文件夹,使用pnpm init生成package.json,然后安装typescript和@types/node。

pnpm 复制代码
- pnpm install typescript @types/node --dev-save

命令行交互插件使用cac,前端编译使用vite

pnpm 复制代码
- pnpm install cac vite

2、创建入口文件

在根目录下创建src和bin目录,src用于存放业务代码,src目录下创建node目录,node目录下创建cli.ts和dev.ts,bin目录下再创建index.js,作为脚本入口以及tsconfig.json。目录结构如下:

diff 复制代码
- bin
   |--- index.js
- src
   |--- node
         |--- cli.ts
         |--- dev.ts
- package.json
- pnpm-lock.yaml
- tsconfig.json

3、搭建开发环境下的脚本

首先在脚本入口文件添加以下内容:

node 复制代码
// /bin/index.js

#!/usr/bin/env node
require("../dist/node/cli");

tsconfig.json文件增加ts的编译出入口。

json 复制代码
{
  "compilerOptions": {
    "module": "commonjs",
    "outDir": "dist",
    "rootDir": "src",
    "target": "ESNext"
  }
}

package.json文件增加如下配置:

json 复制代码
{
  "main": "index.js",
  "scripts": {
    "dev": "tsc -w"
  },
  "bin": {
    "v-island": "bin/island.js" // npm link后安装到全局的脚本入口
  },
  .
  .
  .
}

4、搭建开发环境下的web服务

使用vite搭建web服务,解析更快,插件丰富,是现在最流行的前端脚手架框架。首先dev.ts添加以下内容:

ts 复制代码
import { createServer } from "vite";

export default function createDevServer(root: string) {
  return createServer({root});
}

导出vite服务。

再在cli.ts添加以下内容:

ts 复制代码
import cac from "cac";
import createDevServer from './dev';

const cli = cac("island").version("0.0.1").help();

cli.command("dev [root]", "start dev server").action(async (root: string) => {
  const server = await createDevServer(root);
  await server.listen();
  server.printUrls();
});

cli.parse();

5、完成脚本安装

脚本是用于启动开发环境下的web服务以及编译前端文件,所以首先执行pnpm run dev,将脚本文件编译成js文件,然后执行npm link将脚本安装到全局。最后执行v-island dev就会启动开发环境下web服务,这就完成了该项目的基本搭建。

相关推荐
牧马少女16 小时前
css 画一个圆角渐变色边框
前端·css
zy happy17 小时前
RuoyiApp 在vuex,state存储nickname vue2
前端·javascript·小程序·uni-app·vue·ruoyi
小雨青年17 小时前
Cursor 项目实战:AI播客策划助手(二)—— 多轮交互打磨播客文案的技术实现与实践
前端·人工智能·状态模式·交互
533_17 小时前
[vue3] h函数,阻止事件冒泡
javascript·vue.js·elementui
蒲公英源码17 小时前
php+vue知识付费系统前后端全套源码
vue.js·php
通往曙光的路上17 小时前
day22_用户授权 头像上传
javascript·vue.js·ecmascript
小阳生煎17 小时前
Vue实现全局设置一个刷新按钮 只刷新当面路由页面 不跳转操作功能
vue.js·vue
小光学长17 小时前
基于Vue的儿童手工创意店管理系统as8celp7(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
前端·数据库·vue.js
meichaoWen17 小时前
【Vue】Vue框架的基础知识强化
前端·javascript·vue.js
jingling55518 小时前
Flutter | 基础环境配置和创建flutter项目
前端·flutter