基于Vue3+Vite+TS+AntDv+ Pinia从零搭建一个项目

基于Vue3+Vite+TS+AntDv+ Pinia从零搭建一个项目
摘要由CSDN通过智能技术生成


以下内容是自己搭建过程中的一个小记录,给需要的小伙伴做一个参考,嘿嘿☺,如有不足之处,欢迎各位小伙伴留言指出哦,大家共同进步 吖吖吖

技术栈

1、前端框架:Vue3.x
2、构建工具:Vite2.x
3、编程语言:TypeScript
4、状态管理工具:Pinia
5、路由管理工具:Vue Router
6、前端UI框架:Ant Design Vue
7、Http请求工具:Axios
8、CSS处理器:Less/Scss/Stylus

项目目录结构

...
├─ public
├─ src
│    ├─ api // 用于存储项目所有的api,可根据模块添加多个文件夹以区分
│    ├─ asseets // 用于存储项目所有的静态资源
│    ├─ components // 用于存储所有的公共组件,可根据模块新建对应的文件夹以区分
│    ├─ plugins // 用于存储项目所有的插件或工具函数(就是通常所说的utils文件夹,这里我起的名叫plugins)
│    ├─ router // 用于项目路由配置
│    ├─ store // 用于项目全局状态管理配置
│    ├─ views // 用于项目页面目录
│    ├─ App.vue // 项目根文件
│    ├─ env.d.ts
│    ├─ main.ts // 项目配置入口文件
├─ .gitignore
├─ index.html
├─ package-lock.json
├─ package.json
├─ tsconfig.json // TypeScript 配置文件
├─ tsconfig.node.json
├─ vite.config.ts // Vite 配置文件
...

一、使用vite搭建环境

1、安装vite环境

npm init @vitejs/app
或
yarn create @vitejs/app

2、初始化项目

npm init @vitejs/app project-name
或
yarn create @vitejs/app project-name

在这里插入图片描述

【注:终端里需要填的内容】
project-name 项目的名字
select-a-framework 所需要使用的技术栈
select-a-variant 所需要使用的语言类型

~~如此一来,以上,项目初始化已经完成!

接下来就可以在终端执行npm install来安装依赖,安装完成后项目就创建完成了,执行npm run dev,项目启动。
在这里插入图片描述

3、修改配置

  • 3.1、根目录 vite.config.ts
import {
    defineConfig } from 'vite';
import vue from '@vitejs/plugin-vue';
// 如果编辑器提示 path 模块找不到,则可以安装一下 @types/node -> npm i @types/node -D
import {
    resolve } from 'path';

// https://vitejs.dev/config/
export default defineConfig({
   
  plugins: [vue()],
  resolve: {
   
    alias: {
   
      '@': resolve(__dirname, 'src') // 设置 `@` 指向 `src` 目录
    }
  },
  base: './', // 设置打包路径
  server: {
   
    port: 4000, // 设置服务启动端口号
    open: true, // 设置服务启动时是否自动打开浏览器
    cors: true // 允许跨域

    // 设置代理,根据我们项目实际情况配置
    // proxy: {
   
    //   '/api': {
   
    //     target: 'http://xxx.xxx.xxx.xxx:8000',
    //     changeOrigin: true,
    //     secure: false,
    //     rewrite: (path) => path.replace('/api/', '/')
    //   }
    // }
  }
})

path模块是node中的一个核心模块,需要安装让 TypeScript 支持 node.js 的依赖包。
如果编辑器提示 path 模块找不到,则可以安装一下 @types/node。命令如下:

npm install @types/node -D
  • 3.2、根目录 tsconfig.json
    加上 “paths”: { “@/” : [“./src/”]} 这个配置,用于配置绝对路径的,ts和vue3组合时绝对路径需要这么配置
{
   
  "compilerOptions": {
   
    "target": "esnext",
    "useDefineForClassFields": true,
    "module": "esnext",
    "moduleResolution": "node",
    "strict": true,
    "jsx": "preserve",
    "sourceMap": true,
    "resolveJsonModule": true,
    "isolatedModules": true,
    "esModuleInterop": true,
    "lib": ["esnext", "dom"],
    "skipLibCheck": true,
    "paths": {
   
      "@/*":[
        "./src/*"
      ]
    }
  },
  "include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"],
  
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,下面是搭建 Vue 3.0 + Vite + Pinia + TypeScript 的步骤: 1. 安装 Node.js,推荐使用 LTS 版本。 2. 安装 Vite: ``` npm init vite-app my-project ``` 这里我们使用 Vite 初始化一个项目,名称为 my-project。 3. 安装依赖: ``` cd my-project npm install ``` 4. 安装 Vue 3.0: ``` npm install vue@next ``` 5. 安装 Pinia: ``` npm install pinia ``` 6. 安装 TypeScript: ``` npm install --save-dev typescript ``` 7. 配置 TypeScript: 在项目根目录下创建 `tsconfig.json` 文件,内容如下: ```json { "compilerOptions": { "target": "esnext", "module": "esnext", "strict": true, "jsx": "preserve", "sourceMap": true, "moduleResolution": "node", "esModuleInterop": true, "experimentalDecorators": true, "emitDecoratorMetadata": true, "skipLibCheck": true, "forceConsistentCasingInFileNames": true }, "include": ["src/**/*.ts", "src/**/*.tsx", "tests/**/*.ts", "tests/**/*.tsx"], "exclude": ["node_modules"] } ``` 8. 安装 Pinia Devtools(可选): ``` npm install @pinia/devtools --save-dev ``` 9. 在 `main.ts` 中进行配置: ```typescript import { createApp } from 'vue' import { createPinia } from 'pinia' import App from './App.vue' const app = createApp(App) // 创建 Pinia 实例 const pinia = createPinia() // 将 Pinia 实例挂载到 app 上 app.use(pinia) app.mount('#app') ``` 10. 编写组件: 在 `src` 目录下创建一个 `components` 目录,然后创建一个 `HelloWorld.vue` 组件: ```vue <template> <div> <h1>Hello, {{ name }}</h1> <button @click="increase">Increase</button> <p>{{ count }}</p> </div> </template> <script lang="ts"> import { defineComponent } from 'vue' import { useStore } from 'pinia' export default defineComponent({ name: 'HelloWorld', setup() { const store = useStore() const name = store.getters.getName const count = store.state.count const increase = () => { store.commit('increase') } return { name, count, increase } }, }) </script> ``` 11. 在 `App.vue` 中使用组件: ```vue <template> <HelloWorld /> </template> <script lang="ts"> import { defineComponent } from 'vue' import HelloWorld from './components/HelloWorld.vue' export default defineComponent({ name: 'App', components: { HelloWorld, }, }) </script> ``` 12. 运行项目: ``` npm run dev ``` 至此,我们已经成功搭建Vue 3.0 + Vite + Pinia + TypeScript项目

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值