国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > JS > 正文

ES6 fetch函數(shù)與后臺交互實現(xiàn)

2024-05-06 16:46:49
字體:
供稿:網(wǎng)友

最近在學(xué)習(xí)react-native,遇到調(diào)用后端接口的問題.看了看官方文檔,推薦使用es6的fetch來與后端進行交互,在網(wǎng)上找了一些資料.在這里整理,方便以后查詢.

1.RN官方文檔中,可使用XMLHttpRequest

var request = new XMLHttpRequest();request.onreadystatechange = (e) = >{  if (request.readyState !== 4) {    return;  }  if (request.status === 200) {    console.log('success', request.responseText);  } else {    console.warn('error');  }};request.open('GET', 'https://mywebsite.com/endpoint.php');request.send();

這是http的原生方法,這里不做多的介紹.

2.RN官方文檔中,推薦使用fetch

fetch('https://mywebsite.com/endpoint/', {  method: 'POST',  headers: {    'Accept': 'application/json',    'Content-Type': 'application/json',  },  body: JSON.stringify({    firstParam: 'yourValue',    secondParam: 'yourOtherValue',  })}).then(function(res) {  console.log(res)})

body中的數(shù)據(jù)就是我們需要向服務(wù)器提交的數(shù)據(jù),比如用戶名,密碼等;如果上述body中的數(shù)據(jù)提交失敗,那么你可能需要把數(shù)據(jù)轉(zhuǎn)換成如下的表單提交的格式:

fetch('https://mywebsite.com/endpoint/', {  method: 'POST',  headers: {    'Content-Type': 'application/x-www-form-urlencoded',  },  body: 'key1=value1&key2=value2'}).then(function(res) {    console.log(res)})

這樣可以獲取純文本的返回數(shù)據(jù).

如果你需要返回json格式的數(shù)據(jù):

fetch('https://mywebsite.com/endpoint/').then(function(res) {  if (res.ok) {    res.json().then(function(obj) {      // 這樣數(shù)據(jù)就轉(zhuǎn)換成json格式的了    })  }}, function(ex) {  console.log(ex)})

fetch模擬表單提交:

fetch('doAct.action', {   method: 'post',   headers: {    "Content-type": "application/x-www-form-urlencoded; charset=UTF-8"   },   body: 'foo=bar&lorem=ipsum'  }) .then(json)  .then(function (data) {   console.log('Request succeeded with JSON response', data);  })  .catch(function (error) {   console.log('Request failed', error);  });

不過無論是ajax還是fetch,都是對http進行了一次封裝,大家各取所好吧.

參考文檔:https://developer.mozilla.org/zh-CN/docs/Web/API/GlobalFetch/fetch

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


注:相關(guān)教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 曲麻莱县| 桃江县| 安仁县| 日喀则市| 平罗县| 民县| 南阳市| 红桥区| 济南市| 安宁市| 常山县| 卢龙县| 阿城市| 炉霍县| 佛冈县| 奈曼旗| 乐业县| 方正县| 新丰县| 吴江市| 家居| 永济市| 星子县| 溧水县| 沙湾县| 田阳县| 菏泽市| 伊宁县| 沁水县| 延吉市| 广汉市| 兴海县| 尖扎县| 茌平县| 晋宁县| 赤水市| 敦煌市| 建平县| 鹿泉市| 仙居县| 高安市|