基础的前端vite项目创建

1. 准备环境

确保你的计算机上已安装Node.js和npm(或yarn,如果你更偏好使用yarn)。你可以通过运行node -vnpm -v(或yarn -v)来检查它们是否已安装以及安装的版本。

2. 安装Vite

在命令行(终端)中,使用npm(或yarn)全局安装Vite。虽然对于单个项目来说,全局安装不是必需的,但这样做可以确保你可以在任何地方使用Vite命令。

3.创建一个vite前端项目

yarn create vite 项目名 --template vue

4. 进入到创建的项目路径

cd  项目名

 yarn //安装依赖

5.安装配置项目所需的第三方依赖

第三方依赖vue-router,vuex ,element-plus, axios ,qs ,element-plus-icon是vite基础项目的必须依赖,其他依赖可根据自己实际需求来安装。

5.1.配置路由

5.1.1.安装路由:

yarn  add   vue-router

5.1.2 .vue-router的配置 

在src创建router目录, 在router目录创建index.js,将以下基本内容复制粘贴。

import { createRouter, createWebHistory} from 'vue-router'
​
​
const routes = [
    
];
​
const router = createRouter({
        routes,  //路由规则
        history:  createWebHistory(),
        linkActiveClass:'active'
    });
​
//全局前置路由守卫
​
​
export default router;

在main.js文件中配置router

import router from './router'
app.use(router)

5.2.配置vuex (全局的状态管理)

5.2.1.安装vuex

yarn add vuex

5.2.2.vuex的配置

在src目录下创建store目录, 在store目录创建一个index.js

//1.导入createStore函数
import {createStore} from 'vuex'
​
​
//2.创建vuex的核心对象
//定义一个状态
const  state={
}
//state的计算属性
const getters={
​
}
​
//修改状态的  同步的
const  mutations ={
​
}
​
//actions  操作  定义事件,让组件触发事件
const actions = {
   
       
}
​
const plugins =[]
​
//3. 调用createStore创建store对象
const store = createStore({
    state,                 
    mutations,
    actions,
    getters,
    plugins,
});
​
//4.暴露store
export default store;

在main.js配置store

import store from './store'
app.use(store)

5.3.配置element-plus

5.3.1 .安装element-plus

yarn add  element-plus

5.3.2.在main.js配置

import ElementPlus from 'element-plus'
import 'element-plus/dist/index.css'
app.use(ElementPlus)

5.4.配置element-plus图标

5.4.1.安装element-plus图标

yarn add @element-plus/icons-vue

5.4.2. 在main.js配置

import * as ElementPlusIconsVue from '@element-plus/icons-vue'
​
for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
  app.component(key, component)
}

5.5.配置axios

5.5.1 安装axios和qs

yarn add  axios
yarn add   qs

5.5.2.axios的配置

在src目录创建一个http目录, 创建两个文件

1.axios实例配置文件: config.js,将以下基本配置复制粘贴

//axios的配置文件
export default {
    method: 'get',
    // 基础url前缀
    baseUrl: 'http://localhost:8080',//根据项目进行修改
    // 请求头信息
    headers: {
      //默认的请求context-type: application/json
      'Content-Type': 'application/json;charset=UTF-8'
    },
    // 参数
    data: {},
    // 设置超时时间
    timeout: 10000,
    // 携带凭证  是否携带cookie
    withCredentials: true,
    // 返回数据类型
    responseType: 'json'
  }

2.创建一个request.js 封装axios 工具库

import { ElLoading,ElMessage } from 'element-plus'
import axios from 'axios'
import qs from 'qs'  //把json进行序列化成key/value
import config from './config'
import  $router from '../router'
​
const instance = axios.create({
    baseURL: config.baseUrl,
    headers: config.headers,
    timeout: config.timeout,
    withCredentials: config.withCredentials
  })
// request 拦截器
instance.interceptors.request.use(
    config => {
      let token = sessionStorage.getItem("token");
      // 带上token
      if (token) {
        config.headers.token = token
      }
      return config
    });
​
const request = async function (loadtip, query) {
    let loading
    if (loadtip) {
        loading = ElLoading.service({
            lock: true,
            text: '正在加载...',
            background: 'rgba(0, 0, 0, 0.7)',
        })
    }
    const res = await instance.request(query)
    if (loadtip) {
        loading.close()
    }
    if (res.data.meta.status === 401) {
        //ElMessage.error();
        $router.push({ path: '/login' })
        return Promise.reject(res.data) //reject()  catch捕获
    } else if (res.data.meta.status === 500) {
        return Promise.reject(res.data)
    } else if (res.data.meta.status === 501) {
        return Promise.reject(res.data)
    } else if (res.data.meta.status === 502) {
        $router.push({ path: '/login' })
        return Promise.reject(res.data)
    } else {
        return Promise.resolve(res.data)  // then()
    }
        /*
        .catch(e => {
            if (loadtip) {
                loading.close()
            }
            return Promise.reject(e.msg)
        })
        */
}
const get = function (url, params) {
    const query = {
        url: url,
        method: 'get',
        withCredentials: true,
        timeout: 30000,
        params: params,  //params: queryString
        headers: { 'request-ajax': true }
    }
    return request(false, query)
}
const post = function (url, params) {
    const query = {
        url: url,
        method: 'post',
        withCredentials: true,
        timeout: 30000,
        data: params,  //请求体
        headers: { 'Content-Type': 'application/json', 'request-ajax': true }
    }
    return request(false, query)
}
const postWithLoadTip = function (url, params) {
    const query = {
        url: url,
        method: 'post',
        withCredentials: true,
        timeout: 30000,
        data: params,
        headers: { 'Content-Type': 'application/json', 'request-ajax': true }
    }
    return request(true, query)
}
const postWithOutLoadTip = function (url, params) {
    const query = {
        url: url,
        method: 'post',
        withCredentials: true,
        timeout: 30000,
        data: params,
        headers: { 'Content-Type': 'application/json', 'request-ajax': true }
    }
    return request(false, query)
}
const postWithUrlEncoded = function (url, params) {
    const query = {
        url: url,
        method: 'post',
        withCredentials: true,
        timeout: 30000,
        data: qs.stringify(params), //params:json  qs.stringify(json) --> 转换key/value
        headers: { 'Content-Type': 'application/x-www-form-urlencoded', 'request-ajax': true }
    }
    return request(false, query)
}
​
const del = function (url, params) {
    const query = {
        url: url,
        method: 'DELETE',
        withCredentials: true,
        timeout: 30000,
        data: params,
        headers: { 'Content-Type': 'application/json', 'request-ajax': true }
    }
    return request(true, query)
}
const put = function (url, params) {
    const query = {
        url: url,
        method: 'PUT',
        withCredentials: true,
        timeout: 30000,
        data: params,
        headers: { 'Content-Type': 'application/json', 'request-ajax': true }
    }
    return request(true, query)
}
​
​
​
const form = function (url, params) {
    const query = {
        url: url,
        method: 'post',
        withCredentials: true,
        timeout: 30000,
        data: params,
        headers: { 'Content-Type': 'multipart/form-data', 'request-ajax': true }
    }
    return request(false, query)
}
​
​
export default {
    post,
    postWithLoadTip,
    postWithOutLoadTip,
    postWithUrlEncoded,
    get,
    form,
    del,
    put
}

3.在main.js配置

import $http from './http/request.js'
app.config.globalProperties.$http =  $http

Vite 是一种新型的前端构建工具,它基于原生ESM来提供开箱即用的模块热替换(HMR)和懒加载等功能。在 Vue 项目中添加 Vite,可以让你利用 Vite 的诸多优势,比如快速的开发服务器启动时间和热模块替换等。 要在一个 Vue 项目中添加 Vite,你可以按照以下步骤操作: 1. 移除原有构建系统(如 Webpack)相关的依赖和配置文件,比如 `vue.config.js` 或者 `webpack.config.js`,以及它们可能依赖的其他包。 2. 安装 Vite 相关的依赖到你的项目中。可以通过 npm 或 yarn 来安装 Vite 作为项目的开发依赖(devDependencies)。 例如,使用 npm 安装 Vite: ```bash npm install --save-dev vite @vitejs/plugin-vue ``` 3. 在项目根目录创建一个新的 Vite 配置文件 `vite.config.js`,并使用 @vitejs/plugin-vue 插件来支持 Vue 单文件组件(SFC)的处理。 一个基本的 `vite.config.js` 配置可能看起来像这样: ```javascript import { defineConfig } from 'vite'; import vue from '@vitejs/plugin-vue'; // https://vitejs.dev/config/ export default defineConfig({ plugins: [vue()] }); ``` 4. 更新项目的 `package.json` 文件,将构建和开发脚本替换为使用 Vite 的命令。 例如,将原有的 `dev` 和 `build` 脚本替换为: ```json "scripts": { "dev": "vite", "build": "vite build", "serve": "vite preview" } ``` 5. 如果你的项目使用了其他插件或配置,可能需要做进一步的适配工作,确保这些插件或配置与 Vite 兼容。 完成以上步骤后,你的 Vue 项目应该已经可以使用 Vite 来进行开发和构建了。运行 `npm run dev` 将启动 Vite 开发服务器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值