使用vue3.x+vite+element-ui+vue-router+vuex+axios搭建项目

 更新时间:2021年08月24日 11:39:13   作者:YuShiYue  
因为vue3出了一段时间了,element也出了基于vue3.x版本的element-plus,这篇文章就拿他们搭建一个项目,希望能给你带来帮助

一. 参考文档

vite官方文档

vue3.x官方文档

vue-router4.x官方文档

vuex4.x官方文档

element-ui3.x官方文档

Ant Design Vue2.x官方文档

axios文档

二. vite搭建项目

  • 安装
# npm 安装
npm init vite@latest

# yarn 安装
yarn create vite

# 快速安装vue模板项目
yarn create vite my-vue-app --template vue

npm init vite@latest my-vue-app -- --template vue

image-20210818170557952

  • 运行
npm run dev 

# or
yarn dev

image-20210818170733034

三. 配置element-ui

  • 下载包

npm install element-plus --save

修改src/main.js

import { createApp } from 'vue'

import ElementPlus from 'element-plus';
import 'element-plus/lib/theme-chalk/index.css';

import App from './App.vue'

const app = createApp(App)
app.use(ElementPlus)
app.mount('#app')

验证是否配置成功

image-20210818171148345

如果组件要按需引入的话可以参考文档介绍

image-20210818171247339

四. 配置vue-router

从vue2迁移

安装

npm install vue-router@4

创建src/router/index.js文件

image-20210818172342806

import { createRouter, createWebHistory } from 'vue-router'

const routes = [
  {
    path: '/demo',
    name: 'demo',
    component: () => import('../views/demo.vue')
  }
]

const router = createRouter({
  history: createWebHistory(),
  routes
})

export default router

修改main.js

import { createApp } from 'vue'
import ElementPlus from 'element-plus';
import 'element-plus/lib/theme-chalk/index.css';
// 引入路由配置
import router from './router/index'
import App from './App.vue'

const app = createApp(App)
app.use(ElementPlus)
// 注册
app.use(router)
app.mount('#app')

修改App.vue添加路由视图

<template>
  <el-button type="primary">按钮</el-button>
  <router-view></router-view>
</template>

<script>
export default {
  name: 'app'
}
</script>

创建src/views/demo.vue文件

image-20210818172605669

经过以上的过程,访问http://localhost:3000/demo 就可以看到一下界面,表明我们的路由配置成功~

image-20210818172727082

五. 配置vuex 安装

npm install vuex@next --save

创建src/store/index.js文件

image-20210818173206269

import { createStore } from "vuex";

const store = createStore({
  state () {
    return {
      app: '我是app'
    }
  },
  mutations: {

  },
  actions: {

  }
})

export default store

修改src/main.js

import { createApp } from 'vue'
import ElementPlus from 'element-plus';
import 'element-plus/lib/theme-chalk/index.css';
import router from './router/index'
// 引入文件
import store from './store/index'
import App from './App.vue'

const app = createApp(App)
app.use(ElementPlus)
app.use(router)
// 注册
app.use(store)
app.mount('#app')

在App.vue中查看是否配置成功

image-20210818173322287

能够成功打印测配置成功

image-20210818173340721

六. 配置axios

安装

npm install axios -S

创建src/utils/request.js

import axios from 'axios'

const services = axios.create({
  baseURL: 'https://api.apiopen.top',
  timeout: 6000
})

// 请求拦截
services.interceptors.request.use(config => {
  // 在这可以添加一些请求头的逻辑,如配置token
  return config
}, error => {
  return Promise.reject(error)
})

// 响应拦截
services.interceptors.response.use(response => {
  // 在这可以根据实际后台的响应值去进行判断,如code: 0 或者登录失效跳转到登录页等
  return response.data
}, error => {
  return Promise.reject(error)
})

export default services

image-20210818175532400

创建src/api/app.js配置气你跪求方法

import request from '../utils/request'

export const send = () => {
  return request({
    url: '/getJoke',
    method: 'get',
    params: {
      page: 1,
      count: 2,
      type: 'video'
    }
  })
}

image-20210818175614712

在App.vue引入测试

<template>
  <el-button type="primary">按钮</el-button>
  <router-view></router-view>
</template>

<script>
// 引入请求方法 
import { send } from "./api/app";
export default {
  name: "app",
  async mounted() {
    console.log("store>>>", this.$store.state.app);
    // 请求
    const res = await send()
    console.log('res>>>', res)
  },
};
</script>

查看浏览器是否请求成功

image-20210818175730709

七. 总结

经过以上几步就可以搭建一个简单的vue工程化项目,但是实际开发当中肯定不能这么简单,比如别名的配置,这个时候就需要修改vite.config.js去进行别名的配置,还有路由权限的控制以及ui库sass变量的替换等等…

本篇文章就到这里了,希望能给你带来帮助,也希望您能够多多关注脚本之家的更多内容!

相关文章

  • java对图片进行压缩和resize缩放的方法

    java对图片进行压缩和resize缩放的方法

    本篇文章主要介绍了java对图片进行压缩和resize调整的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-07-07
  • Springboot通过谷歌Kaptcha 组件生成图形验证码功能

    Springboot通过谷歌Kaptcha 组件生成图形验证码功能

    Kaptcha是谷歌开源的一款简单实用的图形验证码组件。我个人推荐它的最大原因是容易上手,采用约定大于配置的方式,快速契合到项目中,这篇文章主要介绍了Springboot通过谷歌Kaptcha组件生成图形验证码的方法,需要的朋友可以参考下
    2023-05-05
  • springboot构建docker镜像并推送到阿里云

    springboot构建docker镜像并推送到阿里云

    本文主要介绍了springboot构建docker镜像并推送到阿里云,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-05-05
  • Java实现curl调用带参数接口方法

    Java实现curl调用带参数接口方法

    本文主要介绍了Java实现curl调用带参数接口方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-04-04
  • jdk15的安装与配置全过程记录

    jdk15的安装与配置全过程记录

    这篇文章主要给大家介绍了关于jdk15的安装与配置,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-01-01
  • springboot定时任务详解

    springboot定时任务详解

    这篇文章主要介绍了springboot定时任务的相关资料,帮助大家更好的理解和使用springboot框架,感兴趣的朋友可以了解下
    2021-01-01
  • java中栈和队列的实现和API的用法(详解)

    java中栈和队列的实现和API的用法(详解)

    下面小编就为大家带来一篇java中栈和队列的实现和API的用法(详解)。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • Spring Boot实现邮件发送必会的5种姿势

    Spring Boot实现邮件发送必会的5种姿势

    这篇文章主要给大家介绍了关于Spring Boot实现邮件发送必会的5种姿势,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring Boot具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2019-07-07
  • Spring boot拦截器实现IP黑名单的完整步骤

    Spring boot拦截器实现IP黑名单的完整步骤

    这篇文章主要给大家介绍了关于Spring boot拦截器实现IP黑名单的完整步骤,文中通过示例代码介绍的非常详细,对大家学习或者使用Spring boot拦截器具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧
    2020-06-06
  • SpringBoot MongoDB与MongoDB GridFS基本使用

    SpringBoot MongoDB与MongoDB GridFS基本使用

    这篇文章主要为大家介绍了SpringBoot MongoDB与MongoDB GridFS基本使用示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07

最新评论