溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何使用vue3.x+axios搭建項(xiàng)目

發(fā)布時(shí)間:2021-08-24 15:05:12 來源:億速云 閱讀:996 作者:chen 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“如何使用vue3.x+axios搭建項(xiàng)目”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

目錄
  • 一. 參考文檔

  • 二. vite搭建項(xiàng)目

  • 三. 配置element-ui

  • 四. 配置vue-router

  • 五. 配置vuex 安裝

  • 六. 配置axios


一. 參考文檔

vite官方文檔

vue3.x官方文檔

vue-router4.x官方文檔

vuex4.x官方文檔

element-ui3.x官方文檔

Ant Design Vue2.x官方文檔

axios文檔

二. vite搭建項(xiàng)目

  • 安裝

# npm 安裝
npm init vite@latest

# yarn 安裝
yarn create vite

# 快速安裝vue模板項(xiàng)目
yarn create vite my-vue-app --template vue

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

如何使用vue3.x+axios搭建項(xiàng)目

  • 運(yùn)行

npm run dev 

# or
yarn dev

如何使用vue3.x+axios搭建項(xiàng)目

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

驗(yàn)證是否配置成功

如何使用vue3.x+axios搭建項(xiàng)目

如果組件要按需引入的話可以參考文檔介紹

如何使用vue3.x+axios搭建項(xiàng)目

四. 配置vue-router

從vue2遷移

安裝

npm install vue-router@4

創(chuàng)建src/router/index.js文件

如何使用vue3.x+axios搭建項(xiàng)目

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)
// 注冊(cè)
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>

創(chuàng)建src/views/demo.vue文件

如何使用vue3.x+axios搭建項(xiàng)目

經(jīng)過以上的過程,訪問http://localhost:3000/demo 就可以看到一下界面,表明我們的路由配置成功~

如何使用vue3.x+axios搭建項(xiàng)目

五. 配置vuex 安裝

npm install vuex@next --save

創(chuàng)建src/store/index.js文件

如何使用vue3.x+axios搭建項(xiàng)目

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)
// 注冊(cè)
app.use(store)
app.mount('#app')

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

如何使用vue3.x+axios搭建項(xiàng)目

能夠成功打印測(cè)配置成功

如何使用vue3.x+axios搭建項(xiàng)目

六. 配置axios

安裝

npm install axios -S

創(chuàng)建src/utils/request.js

import axios from 'axios'

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

// 請(qǐng)求攔截
services.interceptors.request.use(config => {
  // 在這可以添加一些請(qǐng)求頭的邏輯,如配置token
  return config
}, error => {
  return Promise.reject(error)
})

// 響應(yīng)攔截
services.interceptors.response.use(response => {
  // 在這可以根據(jù)實(shí)際后臺(tái)的響應(yīng)值去進(jìn)行判斷,如code: 0 或者登錄失效跳轉(zhuǎn)到登錄頁等
  return response.data
}, error => {
  return Promise.reject(error)
})

export default services

如何使用vue3.x+axios搭建項(xiàng)目

創(chuàng)建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+axios搭建項(xiàng)目

在App.vue引入測(cè)試

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

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

查看瀏覽器是否請(qǐng)求成功

如何使用vue3.x+axios搭建項(xiàng)目

“如何使用vue3.x+axios搭建項(xiàng)目”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI