• <fieldset id="8imwq"><menu id="8imwq"></menu></fieldset>
  • <bdo id="8imwq"><input id="8imwq"></input></bdo>
    最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
    問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
    當(dāng)前位置: 首頁 - 科技 - 知識(shí)百科 - 正文

    axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求

    來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:23:22
    文檔

    axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求

    axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求:前言 ajax相信不用過多介紹了,作者堅(jiān)信可以用配置解決的問題,請(qǐng)勿硬編碼,下面話不多說了,來一看看詳細(xì)的介紹吧。 姊妹篇 jQuery進(jìn)階:用最優(yōu)雅的方式寫ajax請(qǐng)求 axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細(xì)的基礎(chǔ)知識(shí)可以參考這
    推薦度:
    導(dǎo)讀axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求:前言 ajax相信不用過多介紹了,作者堅(jiān)信可以用配置解決的問題,請(qǐng)勿硬編碼,下面話不多說了,來一看看詳細(xì)的介紹吧。 姊妹篇 jQuery進(jìn)階:用最優(yōu)雅的方式寫ajax請(qǐng)求 axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細(xì)的基礎(chǔ)知識(shí)可以參考這

    前言

    ajax相信不用過多介紹了,作者堅(jiān)信可以用配置解決的問題,請(qǐng)勿硬編碼,下面話不多說了,來一看看詳細(xì)的介紹吧。

    姊妹篇 jQuery進(jìn)階:用最優(yōu)雅的方式寫ajax請(qǐng)求

    axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細(xì)的基礎(chǔ)知識(shí)可以參考這篇文章://www.gxlcms.com/article/109444.htm

    優(yōu)點(diǎn):

  • 增加一個(gè)ajax接口,只需要在配置文件里多寫幾行就可以
  • 不需要在組件中寫axios調(diào)用,直接調(diào)用api方法,很方便
  • 如果接口有調(diào)整,只需要修改一下接口配置文件就可以
  • 統(tǒng)一管理接口配置
  • 1. content-type配置

    // filename: content-type.js
    module.exports = {
     formData: 'application/x-www-form-urlencoded; charset=UTF-8',
     json: 'application/json; charset=UTF-8'
    }

    2. api 配置

    // filename: api-sdk-conf.js
    import contentType from './content-type'
    export default {
     baseURL: 'http://192.168.40.231:30412',
     apis: [
     {
     name: 'login',
     path: '/api/security/login?{{id}}',
     method: 'post',
     contentType: contentType.formData,
     status: {
     401: '用戶名或者密碼錯(cuò)誤'
     }
     }
     ]
    }

    3. request.js 方法

    // request.js
    import axios from 'axios'
    import qs from 'qs'
    import contentType from '@/config/content-type'
    import apiConf from '@/config/api-sdk-conf'
    var api = {}
    // render 函數(shù)用來渲染路徑上的變量, 算是一個(gè)微型的模板渲染工具
    // 例如render('/{{userId}}/{{type}}/{{query}}', {userId:1,type:2, query:3})
    // 會(huì)被渲染成 /1/2/3
    function render (tpl, data) {
     var re = /{{([^}]+)?}}/
     var match = ''
     while ((match = re.exec(tpl))) {
     tpl = tpl.replace(match[0], data[match[1]])
     }
     return tpl
    }
    // fire中的this, 會(huì)動(dòng)態(tài)綁定到每個(gè)接口上
    function fire (query = {}, payload = '') {
     // qs 特別處理 formData類型的數(shù)據(jù)
     if (this.contentType === contentType.formData) {
     payload = qs.stringify(payload)
     } 
     // 直接返回axios實(shí)例,方便調(diào)用then,或者catch方法
     return axios({
     method: this.method,
     url: render(this.url, query),
     data: payload,
     headers: {
     contentType: this.contentType
     }
     })
    }
    apiConf.apis.forEach((item) => {
     api[item.name] = {
     url: apiConf.baseURL + item.path,
     method: item.method,
     status: item.status,
     contentType: item.contentType,
     fire: fire
     }
    })
    export default api

    4. 在組件中使用

    import api from '@/apis/request'
    ...
     api.login.fire({id: '?heiheihei'}, {
     username: 'admin',
     password: 'admin',
     namespace: '_system'
     })
    ...

    瀏覽器結(jié)果:

    Request URL:http://192.168.40.231:30412/api/security/login??heiheihei
    Request Method:POST
    Status Code:200 OK
    Remote Address:192.168.40.231:30412
    Referrer Policy:no-referrer-when-downgrade
    POST /api/security/login??heiheihei HTTP/1.1
    Host: 192.168.40.231:30412
    Connection: keep-alive
    Content-Length: 47
    Accept: application/json, text/plain, */*
    Origin: http://localhost:8080
    contentType: application/x-www-form-urlencoded; charset=UTF-8
    User-Agent: Mozilla/5.0 (Macintosh; Intel Mac OS X 10_12_5) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/62.0.3202.94 Safari/537.36
    Content-Type: application/x-www-form-urlencoded
    Referer: http://localhost:8080/
    Accept-Encoding: gzip, deflate
    Accept-Language: zh-CN,zh;q=0.9,en;q=0.8
    username=admin&password=admin&namespace=_system

    5. 更多

    有個(gè)地方我不是很明白,希望懂的人可以給我解答一下

    如果某個(gè)組件中只需要login方法,但是我這樣寫會(huì)報(bào)錯(cuò)。

    import {login} from '@/apis/request' 

    這樣寫的前提是要在request.js最后寫上

    export var login = api.login 
        

    但是這是我不想要的,因?yàn)槊看卧黾右粋€(gè)接口,這里都要export一次, 這不符合開放閉合原則,請(qǐng)問有什么更好的方法嗎?

    總結(jié)

    聲明:本網(wǎng)頁內(nèi)容旨在傳播知識(shí),若有侵權(quán)等問題請(qǐng)及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

    文檔

    axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求

    axios進(jìn)階實(shí)踐之利用最優(yōu)雅的方式寫ajax請(qǐng)求:前言 ajax相信不用過多介紹了,作者堅(jiān)信可以用配置解決的問題,請(qǐng)勿硬編碼,下面話不多說了,來一看看詳細(xì)的介紹吧。 姊妹篇 jQuery進(jìn)階:用最優(yōu)雅的方式寫ajax請(qǐng)求 axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細(xì)的基礎(chǔ)知識(shí)可以參考這
    推薦度:
    • 熱門焦點(diǎn)

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 欧产日产国产精品精品| 久久免费国产精品一区二区| 国产精品视频一区二区三区经| 三级国产精品| 97精品在线播放| 国产一精品一AV一免费| 亚洲国产精品ⅴa在线观看| 国产观看精品一区二区三区| 国产精品区一区二区三在线播放| 日本精品少妇一区二区三区| 亚洲午夜精品一区二区| 91精品美女在线| 久久精品国产亚洲AV香蕉| 亚洲精品尤物yw在线影院| 国产精品亚洲综合一区| 欧美性videofree精品| 精品少妇无码AV无码专区| 无码人妻精品一区二区三区99仓本 | 国产伦精品一区二区免费| 国产精品免费网站| 成人无码精品1区2区3区免费看| 人妻少妇精品无码专区二区| 亚洲午夜成人精品电影在线观看| 欧美精品黑人粗大| 久久亚洲国产精品123区| 精品国产污污免费网站入口| 国产系列高清精品第一页| 国产精品哟女在线观看| mm1313亚洲国产精品无码试看| 欧美亚洲精品在线| 亚洲国产精品久久久久网站 | 97精品国产91久久久久久| 国产AV国片精品有毛| 国产国拍亚洲精品mv在线观看| 久久精品人人做人人爽电影蜜月| 亚洲精品国产字幕久久不卡| 亚洲精品无码久久久久久| 亚洲精品国产精品乱码视色| 中文字幕乱码中文乱码51精品| 真实国产乱子伦精品一区二区三区| 夜夜精品无码一区二区三区|