欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Vue.js項(xiàng)目API、Router配置拆分實(shí)踐

 更新時(shí)間:2018年03月16日 09:15:06   作者:dunizb  
這篇文章主要介紹了詳解Vue.js項(xiàng)目API、Router配置拆分實(shí)踐,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

前后端分離開發(fā)方式前端擁有更高的控制權(quán)

隨著前端框架技術(shù)的飛速發(fā)展,Router這個(gè)概念也被迅速普及到前端項(xiàng)目中,在早期前后的沒有分離的時(shí)期下,并沒有明確的路由概念,前端頁面跳轉(zhuǎn)大多是通過后端進(jìn)行請求轉(zhuǎn)發(fā)的,比如在Spring MVC項(xiàng)目中,進(jìn)行一個(gè)頁面跳轉(zhuǎn)如下(畫紅線部分):


前端需要一個(gè)超鏈接,鏈接的href=/manager,這樣這個(gè)超鏈接被轉(zhuǎn)發(fā)到scs/waitFollowed路徑指定的頁面。

前后的分離后,前端頁面跳轉(zhuǎn)的方式發(fā)生了變化,不再需要后端處理了,數(shù)據(jù)交換方式也改變了,由此前端需要定義Router配置文件,需要定義API配置文件。在項(xiàng)目的權(quán)限配置管理中,完全不需要后端什么事了,可以說,權(quán)限配置表可以單獨(dú)拿出來由前端維護(hù)了。

比如這個(gè)url字段,在前后端不分離的情況下,嚴(yán)重依賴于后端,url就是后端接口地址,如果需要更改就需要后端修改代碼修改接口地址,而現(xiàn)在,前端可以自由控制url的值是什么了。

在接口層面,前端也會有自己的配置文件,可以對后端提供的接口進(jìn)行重命名,組合等。比如

前端都統(tǒng)一使用模塊名+接口名的方式管理,管后端提供的接口叫啥已經(jīng)不重要,在視覺上和維護(hù)上都比較方便。在頁面上使用,查詢起來也很直觀:

看到DISTRBUTE().Leads.dataGrid這個(gè)接口,就知道這是DISTRBUTE模塊下Leasd功能下的列表查詢接口

Vue.js中的API、Router配置

在Vue.js項(xiàng)目下,一開始我們只使用一個(gè)api.config.js配置文件,所有的接口都定義在這里面,router也一樣,都配置在一個(gè)router.config.js中,下面是我們項(xiàng)目中API配置文件

可以看到,很多的業(yè)務(wù)模塊,很多的接口,已經(jīng)達(dá)到了570多行,隨著業(yè)務(wù)進(jìn)一步推進(jìn),接口快速膨脹,文件越來越大。

這時(shí)候迫切需要拆分,把不同的業(yè)務(wù)模塊單獨(dú)拆分為一個(gè)個(gè)API配置文件。同樣,我們來看看拆分前的Router配置文件:

這樣router一多最大的缺點(diǎn)就是會導(dǎo)致router命名沖突。

拆分!拆分!拆分!

首先考慮API配置文件怎么拆分,對于接口,我們肯定有多套環(huán)境,多套環(huán)境那么API的URL也不一樣,拆分成多個(gè)文件后多個(gè)文件需要共用同一個(gè)獲取apiBase的方法,所以這個(gè)apiBase就要寫在公共的地方,在這里原來的api.config.js就變成了公共配置,apiBase就放在此文件內(nèi)。

export function apiBase() {
 let hostname = window.location.hostname,
  API_BASE_URL = 'http://test2api.dunizb.com';//默認(rèn)環(huán)境
 if(hostname === 'crm.dunizb.cn') { //正式環(huán)境
  API_BASE_URL = 'http://api.dunizb.cn';
 } else if(hostname === 'admin.dunizb.com') {//公網(wǎng)測試環(huán)境
  API_BASE_URL = 'http://testapi.dunizb.com';
 } else if(hostname === 'manager.dunizb.com') {//內(nèi)網(wǎng)測試環(huán)境
  API_BASE_URL = 'http://test2api.dunizb.com';
 }
 return API_BASE_URL;
}

然后在每個(gè)子API配置文件中引入即可:

import {apiBase} from '../api.config';

具體功能API不需要更改,直接拷貝相應(yīng)模塊API到子模塊API配置文件即可。

Router的拆分稍微復(fù)雜一點(diǎn),拆分后的文件目錄與API的目錄相同:

拆分思路也完全一樣,但要保證只有一個(gè)router.start即:

return router.start(App, '#app');

雖然你在子router配置文件中也寫上頁面是能正常工作的,但是Vue.js會在控制臺報(bào)一個(gè)錯誤:

這個(gè)錯誤的意思就是router已經(jīng)啟動,無需啟動多次。所以,子router文件中不能存在 return router.start(App, '#app'); 這樣的代碼。

拆分后router.config.js內(nèi)容如下:

/**
 * 路由總文件
 * Created by Bing on 2017/6/19 0019.
 */
import App from './App';
import authority from './routers/authority';
import publics from './routers/public';
import study from './routers/study';
... ...
export default function(router){
 authority(router);//基礎(chǔ)與權(quán)限模塊
 publics(router);//公共模塊
 study(router);//教學(xué)相關(guān)
 ... ...
 return router.start(App, '#app');
}

而子router配置文件的寫法就是這樣(以study模塊為例):

/**
 * 教學(xué)排課
 * 教研
 * Created by Bing on 2017/6/19 0019.
 */
import courseIndex from 'components/studyCourse/index/index';
import waitCourse from 'components/studyCourse/waitCourse/waitCourse';
import alreadyCourse from 'components/studyCourse/alreadyCourse/alreadyCourse';
import gearCourse from 'components/studyCourse/waitCourse/gearCourse';
import courseWare from 'components/teachingResearch/courseware/courseware.vue';
import courseWareLibrary from 'components/teachingResearch/courseware/library.vue';
export default function(router) {
 router.map({
  '/study/index': {component: courseIndex},
  '/study/waitCourse': {component: waitCourse},//待排課程
  '/study/waitCourse/gearCourse': {component: gearCourse},//待排
  '/study/course': {component: alreadyCourse},//已排課程
  '/tr/courseware': {component: courseWare},//課件管理
  '/tr/courseWare/library': {component: courseWareLibrary},//自主上傳課件庫
 });
}

拆分后,每個(gè)模塊管理它自己領(lǐng)域的router、api,router.config.js和api.config.js就大大瘦身了,也降低了命名沖突的問題和將來混亂的問題。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue常用的修飾符及應(yīng)用場景解讀

    Vue常用的修飾符及應(yīng)用場景解讀

    這篇文章主要介紹了Vue常用的修飾符及應(yīng)用場景解讀,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • 在Vue3項(xiàng)目中使用Jest配置生成測試報(bào)告的示例詳解

    在Vue3項(xiàng)目中使用Jest配置生成測試報(bào)告的示例詳解

    在Vue 3項(xiàng)目中使用Jest進(jìn)行單元測試是一種常見的做法,它可以幫助我們驗(yàn)證代碼的正確性和穩(wěn)定性,本文將介紹如何在Vue 3項(xiàng)目中配置Jest,以生成測試報(bào)告,需要的朋友可以參考下
    2023-09-09
  • vue的一個(gè)分頁組件的示例代碼

    vue的一個(gè)分頁組件的示例代碼

    本篇文章主要介紹了vue的一個(gè)分頁組件的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • web前端vue之vuex單獨(dú)一文件使用方式實(shí)例詳解

    web前端vue之vuex單獨(dú)一文件使用方式實(shí)例詳解

    Vuex 是一個(gè)專為 Vue.js 應(yīng)用程序開發(fā)的狀態(tài)管理模式。這篇文章主要介紹了web前端vue:vuex單獨(dú)一文件使用方式,需要的朋友可以參考下
    2018-01-01
  • Vue2項(xiàng)目配置@指向src路徑方式

    Vue2項(xiàng)目配置@指向src路徑方式

    這篇文章主要介紹了Vue2項(xiàng)目配置@指向src路徑方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • Element中el-tabs左右滑動動畫的實(shí)現(xiàn)

    Element中el-tabs左右滑動動畫的實(shí)現(xiàn)

    本篇博客將詳細(xì)介紹如何在使用 Vue 以及 Element UI 時(shí),實(shí)現(xiàn)一個(gè)具有左右滑動效果的 tab 切換動畫,文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-03-03
  • Vue頁面中引入img圖片的方法

    Vue頁面中引入img圖片的方法

    本文主要介紹了Vue頁面中引入img圖片的方法,文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-10-10
  • vue中使用vue-pdf的方法詳解

    vue中使用vue-pdf的方法詳解

    這篇文章主要介紹了vue中使用vue-pdf的方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • vue?el-input設(shè)置必填提示功能(單個(gè)與多個(gè))

    vue?el-input設(shè)置必填提示功能(單個(gè)與多個(gè))

    有的功能需要設(shè)置必填項(xiàng),當(dāng)然也需要判斷是不是添上了,下面這篇文章主要給大家介紹了關(guān)于vue?el-input設(shè)置必填提示功能(單個(gè)與多個(gè))的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • 解決Vue使用百度地圖BMapGL內(nèi)存泄漏問題?Out?of?Memory

    解決Vue使用百度地圖BMapGL內(nèi)存泄漏問題?Out?of?Memory

    這篇文章主要介紹了解決Vue使用百度地圖BMapGL內(nèi)存泄漏問題?Out?of?Memory,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-12-12

最新評論