色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

Vue 使用typescript如何優(yōu)雅的調(diào)用swagger API

瀏覽:124日期:2022-12-01 13:53:27

Swagger 是一個(gè)規(guī)范和完整的框架,用于生成、描述、調(diào)用和可視化 RESTful 風(fēng)格的 Web 服務(wù),后端集成下Swagger,然后就可以提供一個(gè)在線文檔地址給前端同學(xué)。

Vue 使用typescript如何優(yōu)雅的調(diào)用swagger API

前端如何優(yōu)雅的調(diào)用呢?

入門版

根據(jù)文檔,用axios自動(dòng)來調(diào)用

// 應(yīng)用管理相關(guān)接口import axios from ’../interceptors.js’// 獲取應(yīng)用列表export const getList = (data) => { return axios({ url: ’/app/list?sort=createdDate,desc’, method: ’get’, params: data })}

這里的問題是,有多少個(gè)接口,你就要編寫多少個(gè)函數(shù),且數(shù)據(jù)結(jié)構(gòu)需要查看文檔獲取。

進(jìn)階版本

使用typescript,編寫API,通過Type定義數(shù)據(jù)結(jié)構(gòu),進(jìn)行約束。

問題: 還是需要手寫

優(yōu)雅版本

swagger 其實(shí)是一個(gè)json-schema描述文檔,我們可以基于此,自動(dòng)生成。

很早之前,寫過一個(gè)插件 generator-swagger-2-t, 簡(jiǎn)單的實(shí)現(xiàn)了將swagger生成typescript api。

今天,筆者對(duì)這個(gè)做了升級(jí),方便支持后端返回的泛型數(shù)據(jù)結(jié)構(gòu)。

安裝

需要同時(shí)安裝 Yeoman 和 -swagger-2-ts

npm install -g generator-swagger-2-ts

然后cd到你的工作目錄,執(zhí)行:

yo swagger-2-ts

按提示

輸入swagger-ui 地址,例如http://192.168.86.8:8051/swagger-ui.html 可選生成js 或者 typescript 可以自定義生成的api class名稱、api文件名 API 支持泛型

也可以通過命令行直接傳遞參數(shù)

yo swagger-2-ts --swaggerUrl=http://localhost:8080/swagger-ui.html --className=API --type=typescript --outputFile=api.ts swaggerUrl: swagger ui url swaggerui地址 className: API class name 類名 type: typescript or javascipt outputFile: api 文件保存路徑

生成代碼demo:

export type AccountUserInfo = { disableTime?: string isDisable?: number lastLoginIp?: string lastLoginPlace?: string lastLoginTime?: string openId?: string}export type BasePayloadResponse = { data?: object desc?: string retcode?: string}/** * User Account Controller * @class UserAccountAPI */export class UserAccountAPI {/** * changeUserState * @method * @name UserAccountAPI#changeUserState * @param accountUserInfo - accountUserInfo * @param $domain API域名,沒有指定則使用構(gòu)造函數(shù)指定的 */ changeUserState(parameters: { ’accountUserInfo’: AccountUserInfo, $queryParameters?: any, $domain?: string }): Promise<AxiosResponse<BasePayloadResponse>> { let config: AxiosRequestConfig = { baseURL: parameters.$domain || this.$defaultDomain, url: ’/userAccount/changeUserState’, method: ’PUT’ } config.headers = {} config.params = {} config.headers[ ’Accept’ ] = ’*/*’ config.headers[ ’Content-Type’ ] = ’application/json’ config.data = parameters.accountUserInfo return axios.request(config) } _UserAccountAPI: UserAccountAPI = null; /** * 獲取 User Account Controller API * return @class UserAccountAPI */ getUserAccountAPI(): UserAccountAPI { if (!this._UserAccountAPI) { this._UserAccountAPI = new UserAccountAPI(this.$defaultDomain) } return this._UserAccountAPI }}/** * 管理系統(tǒng)接口描述 * @class API */export class API { /** * API構(gòu)造函數(shù) * @param domain API域名 */ constructor(domain?: string) { this.$defaultDomain = domain || ’http://localhost:8080’ }}

使用

import { API } from ’./http/api/manageApi’// in main.tslet api = new API('/api/')api.getUserAccountAPI().changeUserState({ isDisable: 1 openId: ’open id’})

Vue中最佳實(shí)踐

main.ts 全局定義

import { API } from ’./http/api/manageApi’Vue.prototype.$manageApi = new API(’/api/’)

增加.d.ts

增加types文件,方便使用智能提示

import { API } from ’@/http/api/manageApi’import { MarkAPI } from ’@/http/api/mark-center-api’declare module 'vue/types/vue' { interface Vue { $manageApi: API $markApi: MarkAPI }}

實(shí)際使用

現(xiàn)在可以在vue里直接調(diào)用了。

Vue 使用typescript如何優(yōu)雅的調(diào)用swagger API

this.$manageApi .getUserAccountAPI().changeUserState({isDisable: 1, openId: ’open id’})

開源地址

https://github.com/jadepeng/generator-swagger-2-ts

總結(jié)

到此這篇關(guān)于Vue 使用typescript如何優(yōu)雅的調(diào)用swagger API的文章就介紹到這了,更多相關(guān)Vue 使用typescript內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 久久久久久久国产免费看 | 欧美国产精品不卡在线观看 | 美女张开腿双腿让男人桶 | 免费一级毛片不卡在线播放 | 99久免费精品视频在线观看2 | 日韩精品欧美激情国产一区 | 欧美一区亚洲 | 国产精品成人影院 | 亚洲国产人成中文幕一级二级 | 国产一区二区三区在线视频 | 97国产在线视频 | 欧洲一级鲁丝片免费 | 她也啪在线视频精品网站 | 久久福利精品 | 理论片中文字幕 | 欧美色欧美亚洲高清在线视频 | 伊人久久国产免费观看视频 | 蜜桃日本一道无卡不码高清 | 日韩精品中文字幕在线观看 | 亚洲加勒比久久88色综合1 | 国产一级淫片a免费播放口之 | 一级毛片 在线播放 | 狠狠色噜噜狠狠狠米奇9999 | 永久免费不卡在线观看黄网站 | 精品国产美女福到在线不卡f | 国产在视频线精品视频二代 | 欧美乱爱| 国内精品成人女用 | 久久久综合结合狠狠狠97色 | 日韩精品在线观看免费 | 国产高清精品在线 | 亚洲人成综合 | 日本韩经典三级在线播放 | 999久久久精品视频在线观看 | 国产精品a人片在线观看 | 亚洲国产欧美精品一区二区三区 | 91青青国产在线观看免费 | 日韩精品亚洲专区在线观看 | 国产一级生活片 | 久久这里只有精品视频99 | 欧美一级淫片免费观看 |