<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        axios進階實踐之利用最優雅的方式寫ajax請求

        來源:懂視網 責編:小采 時間:2020-11-27 22:23:22
        文檔

        axios進階實踐之利用最優雅的方式寫ajax請求

        axios進階實踐之利用最優雅的方式寫ajax請求:前言 ajax相信不用過多介紹了,作者堅信可以用配置解決的問題,請勿硬編碼,下面話不多說了,來一看看詳細的介紹吧。 姊妹篇 jQuery進階:用最優雅的方式寫ajax請求 axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細的基礎知識可以參考這
        推薦度:
        導讀axios進階實踐之利用最優雅的方式寫ajax請求:前言 ajax相信不用過多介紹了,作者堅信可以用配置解決的問題,請勿硬編碼,下面話不多說了,來一看看詳細的介紹吧。 姊妹篇 jQuery進階:用最優雅的方式寫ajax請求 axios是Vue官方推薦的ajax庫, 用來取代vue-resource。更多詳細的基礎知識可以參考這

        前言

        ajax相信不用過多介紹了,作者堅信可以用配置解決的問題,請勿硬編碼,下面話不多說了,來一看看詳細的介紹吧。

        姊妹篇 jQuery進階:用最優雅的方式寫ajax請求

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

        優點:

      1. 增加一個ajax接口,只需要在配置文件里多寫幾行就可以
      2. 不需要在組件中寫axios調用,直接調用api方法,很方便
      3. 如果接口有調整,只需要修改一下接口配置文件就可以
      4. 統一管理接口配置
      5. 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: '用戶名或者密碼錯誤'
         }
         }
         ]
        }

        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 函數用來渲染路徑上的變量, 算是一個微型的模板渲染工具
        // 例如render('/{{userId}}/{{type}}/{{query}}', {userId:1,type:2, query:3})
        // 會被渲染成 /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, 會動態綁定到每個接口上
        function fire (query = {}, payload = '') {
         // qs 特別處理 formData類型的數據
         if (this.contentType === contentType.formData) {
         payload = qs.stringify(payload)
         } 
         // 直接返回axios實例,方便調用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'
         })
        ...

        瀏覽器結果:

        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. 更多

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

        如果某個組件中只需要login方法,但是我這樣寫會報錯。

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

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

        export var login = api.login 
            

        但是這是我不想要的,因為每次增加一個接口,這里都要export一次, 這不符合開放閉合原則,請問有什么更好的方法嗎?

        總結

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        axios進階實踐之利用最優雅的方式寫ajax請求

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

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 91大神亚洲影视在线| 亚洲一久久久久久久久| 麻豆视频免费播放| 色噜噜的亚洲男人的天堂| 亚洲不卡无码av中文字幕| 免费污视频在线观看| 久久综合久久综合亚洲| 久久久亚洲精品蜜桃臀| 7723日本高清完整版免费| 色多多A级毛片免费看| 亚洲午夜久久久久久尤物| 国产免费怕怕免费视频观看| 国产日韩AV免费无码一区二区| 亚洲午夜一区二区三区| 国产aⅴ无码专区亚洲av麻豆 | 中国一级特黄的片子免费| 67194在线午夜亚洲| 亚洲人成在线播放网站| 国产精品免费视频一区| 91成年人免费视频| 国产成人免费ā片在线观看老同学| 中文字幕亚洲综合小综合在线 | 亚洲国产成人精品91久久久| 18观看免费永久视频| 美女被免费网站91色| 亚洲国产午夜精品理论片在线播放| 亚洲视频2020| 国产偷v国产偷v亚洲高清| 国产嫩草影院精品免费网址| 黄在线观看www免费看| APP在线免费观看视频| 一级毛片免费观看不收费| 亚洲另类无码专区首页| 亚洲国色天香视频| 亚洲精品无码乱码成人| 亚洲AV无码专区日韩| 国产精品国产自线拍免费软件| 国产va免费精品观看精品| 最近免费中文字幕大全免费版视频| 国产精品美女久久久免费| 特级毛片在线大全免费播放|