現(xiàn)在流行的axios庫不支持jsonp,因此這里推薦一個jsonp庫,簡單易用。以下是介紹:
Easy JSONPA minimal and lightweight JSONP implementation which is used to be a kind of cross domain solutions.
FeaturesImplement JSONP request from the browser
Combine URL query parameters by default behavior
Support the [Promise] API
Limit JSONP request period
Handle network error response
Install# using npm npm i easy-jsonp
# using yarn yarn add easy-jsonp
# using script targetUsage
JSONP only support GET methods, same as easy-JSONP.
The code below show you how to use package as a dependency
// as a request dependency named jsonp import jsonp from "easy-jsonp" const jsonp = require("easy-jsonp").default
jsonp({ url: "http://localhost", // global function named `callback` will be invoked when JSONP response callback: "callback", // any different name from request module timeout: 3000, params: { // eg. ?key0=0&key1=1... key0: 0, key1: 1 } }) .then(res => console.log(res)) .catch(err => console.error(err))
?? Notice: Parameter callback value MUST NOT be same as request module name (eg. dependency named jsonp above code), otherwise request module only works once and function named value of parameter callback will be reset to null (internal implementation) which means the same name request module will be also reset unexpectedly.
For more customization capability, This package wouldn"t convert callback to a new name to prevent unexpected reset.
jsonp({ // custom configuration })
?? Notice: For same reason, parameter callback value MUST NOT be jsonp.
Parametersoptions parameter | type | required | description |
---|---|---|---|
url | String | true | JSONP request address |
timeout | Number | false, default : 6000 milliseconds | how long after timeout error is emitted. 0 to disable |
callback | String | false, default : "jsonpCallback"+Date.now() | global callback function name which is used to handle JSONP response. |
params | Object | false, default: {} | other parameters in query string parameters |
Uncaught SyntaxError: Unexpected token :error
It mostly doesn"t support JSONP request when you are calling a JSON api. The difference between JSON api and JSONP is that JSON api response with an object like { num: 1 } (It will throw a error when client executed this response as a function. ). On the other hand, JSONP will respond with a function wrapped object like callback({ num: 1 }) and we will get what we need when client executed this response as a function.
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/98065.html
摘要:結(jié)果證明,對于以上瀏覽器,在生產(chǎn)環(huán)境使用是可行的。后面可以跟對象,表示等待才會繼續(xù)向下執(zhí)行,如果被或拋出異常則會被外面的捕獲。,,都是現(xiàn)在和未來解決異步的標準做法,可以完美搭配使用。這也是使用標準一大好處。只允許外部傳入成功或失敗后的回調(diào)。 showImg(https://cloud.githubusercontent.com/assets/948896/10188666/bc9a53...
摘要:官網(wǎng)地址聊天機器人插件開發(fā)實例教程一創(chuàng)建插件在系統(tǒng)技巧使你的更加專業(yè)前端掘金一個幫你提升技巧的收藏集。我會簡單基于的簡潔視頻播放器組件前端掘金使用和實現(xiàn)購物車場景前端掘金本文是上篇文章的序章,一直想有機會再次實踐下。 2道面試題:輸入URL按回車&HTTP2 - 掘金通過幾輪面試,我發(fā)現(xiàn)真正那種問答的技術(shù)面,寫一堆項目真不如去刷技術(shù)文章作用大,因此刷了一段時間的博客和掘金,整理下曾經(jīng)被...
摘要:本文詳細講述如何使用原生和來實現(xiàn)。使用可以無刷新地向服務(wù)端發(fā)送請求接收服務(wù)端響應(yīng),并更新頁面。分別要用到的方法和方法。,,都是現(xiàn)在和未來解決異步的標準做法,可以完美搭配使用。這也是使用標準一大好處。 本文詳細講述如何使用原生 JS、jQuery 和 Fetch 來實現(xiàn) AJAX。 AJAX 即 Asynchronous JavaScript and XML,異步的 JavaScript...
首先聲明一下,本文不是要講解fetch的具體用法,不清楚的可以參考MDN fetch教程。 引言 說道fetch就不得不提XMLHttpRequest了,XHR在發(fā)送web請求時需要開發(fā)者配置相關(guān)請求信息和成功后的回調(diào),盡管開發(fā)者只關(guān)心請求成功后的業(yè)務(wù)處理,但是也要配置其他繁瑣內(nèi)容,導(dǎo)致配置和調(diào)用比較混亂,也不符合關(guān)注分離的原則;fetch的出現(xiàn)正是為了解決XHR存在的這些問題。例如下面代碼: f...
閱讀 985·2021-11-22 09:34
閱讀 2168·2021-11-11 16:54
閱讀 2206·2021-09-27 14:00
閱讀 950·2019-08-30 15:55
閱讀 1537·2019-08-29 12:46
閱讀 610·2019-08-26 18:42
閱讀 648·2019-08-26 13:31
閱讀 3191·2019-08-26 11:52