服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - 使用vue3.x+vite+element-ui+vue-router+vuex+axios搭建项目

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

2021-12-02 12:54YuShiYue Java教程

因为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

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

  • 运行
npm run dev 

# or
yarn dev

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

 

三. 配置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")

验证是否配置成功

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

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

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

 

四. 配置vue-router

从vue2迁移

安装

npm install vue-router@4

创建src/router/index.js文件

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

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文件

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

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

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

 

五. 配置vuex 安装

npm install vuex@next --save

创建src/store/index.js文件

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

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中查看是否配置成功

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

能够成功打印测配置成功

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

 

六. 配置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

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

创建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"
    }
  })
}

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

在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>

查看浏览器是否请求成功

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

 

七. 总结

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

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

原文链接:https://blog.csdn.net/YuShiYue/article/details/119786036

延伸 · 阅读

精彩推荐
  • Java教程Java实现抢红包功能

    Java实现抢红包功能

    这篇文章主要为大家详细介绍了Java实现抢红包功能,采用多线程模拟多人同时抢红包,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙...

    littleschemer13532021-05-16
  • Java教程20个非常实用的Java程序代码片段

    20个非常实用的Java程序代码片段

    这篇文章主要为大家分享了20个非常实用的Java程序片段,对java开发项目有所帮助,感兴趣的小伙伴们可以参考一下 ...

    lijiao5352020-04-06
  • Java教程小米推送Java代码

    小米推送Java代码

    今天小编就为大家分享一篇关于小米推送Java代码,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧...

    富贵稳中求8032021-07-12
  • Java教程xml与Java对象的转换详解

    xml与Java对象的转换详解

    这篇文章主要介绍了xml与Java对象的转换详解的相关资料,需要的朋友可以参考下...

    Java教程网2942020-09-17
  • Java教程升级IDEA后Lombok不能使用的解决方法

    升级IDEA后Lombok不能使用的解决方法

    最近看到提示IDEA提示升级,寻思已经有好久没有升过级了。升级完毕重启之后,突然发现好多错误,本文就来介绍一下如何解决,感兴趣的可以了解一下...

    程序猿DD9332021-10-08
  • Java教程Java BufferWriter写文件写不进去或缺失数据的解决

    Java BufferWriter写文件写不进去或缺失数据的解决

    这篇文章主要介绍了Java BufferWriter写文件写不进去或缺失数据的解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望...

    spcoder14552021-10-18
  • Java教程Java8中Stream使用的一个注意事项

    Java8中Stream使用的一个注意事项

    最近在工作中发现了对于集合操作转换的神器,java8新特性 stream,但在使用中遇到了一个非常重要的注意点,所以这篇文章主要给大家介绍了关于Java8中S...

    阿杜7482021-02-04
  • Java教程Java使用SAX解析xml的示例

    Java使用SAX解析xml的示例

    这篇文章主要介绍了Java使用SAX解析xml的示例,帮助大家更好的理解和学习使用Java,感兴趣的朋友可以了解下...

    大行者10067412021-08-30