React Native - 11 - 網絡處理

許多移動應用程序需要從遠程URL加載資源茶敏。您可能希望對REST API發(fā)出POST請求府适,或者您可能只需從另一臺服務器獲取一大塊靜態(tài)內容。

Using Fetch

React Native為您的網絡需求提供了獲取API塘秦。如果您以前使用過XMLHttpRequest或其他網絡API歹袁,Fetch看起來會很熟悉锹安。

發(fā)出請求

要從任意網址獲取內容叫榕,只需傳遞網址即可獲认ㄉ摹:

fetch('https://mywebsite.com/mydata.json');

設置頭參數玩裙,發(fā)送POST請求

fetch('[https://mywebsite.com/endpoint/](https://mywebsite.com/endpoint/)', {
  method: 'POST',
  headers: {
    Accept: 'application/json',
    'Content-Type': 'application/json',
  },
  body: JSON.stringify({
    firstParam: 'yourValue',
    secondParam: 'yourOtherValue',
  }),
});

處理響應內容

網絡是一種固有的異步操作兼贸。提取方法將返回一個Promise,使得直接編寫以異步方式工作的代碼:

function getMoviesFromApiAsync() {
  return fetch('[https://facebook.github.io/react-native/movies.json](https://facebook.github.io/react-native/movies.json)')
    .then((response) => response.json())
    .then((responseJson) => {
      return responseJson.movies;
    })
    .catch((error) => {
      console.error(error);
    });
}

您也可以在React Native應用程序中使用建議的ES2017 async / await語法:

async function getMoviesFromApi() {
  try {
    let response = await fetch(
      '[https://facebook.github.io/react-native/movies.json](https://facebook.github.io/react-native/movies.json)'
    );
    let responseJson = await response.json();
    return responseJson.movies;
  } catch (error) {
    console.error(error);
  }
}

不要忘記抓取任何可能會被拋出的錯誤吃溅,否則會被默默地拋棄溶诞。

?著作權歸作者所有,轉載或內容合作請聯系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市决侈,隨后出現的幾起案子螺垢,更是在濱河造成了極大的恐慌,老刑警劉巖赖歌,帶你破解...
    沈念sama閱讀 218,858評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件枉圃,死亡現場離奇詭異,居然都是意外死亡庐冯,警方通過查閱死者的電腦和手機孽亲,發(fā)現死者居然都...
    沈念sama閱讀 93,372評論 3 395
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來展父,“玉大人返劲,你說我怎么就攤上這事∑苘裕” “怎么了旭等?”我有些...
    開封第一講書人閱讀 165,282評論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長衡载。 經常有香客問我搔耕,道長,這世上最難降的妖魔是什么痰娱? 我笑而不...
    開封第一講書人閱讀 58,842評論 1 295
  • 正文 為了忘掉前任弃榨,我火速辦了婚禮,結果婚禮上梨睁,老公的妹妹穿的比我還像新娘鲸睛。我一直安慰自己,他們只是感情好坡贺,可當我...
    茶點故事閱讀 67,857評論 6 392
  • 文/花漫 我一把揭開白布官辈。 她就那樣靜靜地躺著箱舞,像睡著了一般。 火紅的嫁衣襯著肌膚如雪拳亿。 梳的紋絲不亂的頭發(fā)上晴股,一...
    開封第一講書人閱讀 51,679評論 1 305
  • 那天,我揣著相機與錄音肺魁,去河邊找鬼电湘。 笑死,一個胖子當著我的面吹牛鹅经,可吹牛的內容都是我干的寂呛。 我是一名探鬼主播,決...
    沈念sama閱讀 40,406評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼瘾晃,長吁一口氣:“原來是場噩夢啊……” “哼贷痪!你這毒婦竟也來了?” 一聲冷哼從身側響起蹦误,我...
    開封第一講書人閱讀 39,311評論 0 276
  • 序言:老撾萬榮一對情侶失蹤劫拢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后胖缤,有當地人在樹林里發(fā)現了一具尸體尚镰,經...
    沈念sama閱讀 45,767評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 37,945評論 3 336
  • 正文 我和宋清朗相戀三年哪廓,在試婚紗的時候發(fā)現自己被綠了狗唉。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 40,090評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡涡真,死狀恐怖分俯,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情哆料,我是刑警寧澤缸剪,帶...
    沈念sama閱讀 35,785評論 5 346
  • 正文 年R本政府宣布,位于F島的核電站东亦,受9級特大地震影響杏节,放射性物質發(fā)生泄漏。R本人自食惡果不足惜典阵,卻給世界環(huán)境...
    茶點故事閱讀 41,420評論 3 331
  • 文/蒙蒙 一奋渔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧壮啊,春花似錦嫉鲸、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,988評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽座菠。三九已至,卻和暖如春藤树,著一層夾襖步出監(jiān)牢的瞬間浴滴,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,101評論 1 271
  • 我被黑心中介騙來泰國打工也榄, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留巡莹,地道東北人司志。 一個月前我還...
    沈念sama閱讀 48,298評論 3 372
  • 正文 我出身青樓甜紫,卻偏偏與公主長得像,于是被迫代替她去往敵國和親骂远。 傳聞我的和親對象是個殘疾皇子囚霸,可洞房花燭夜當晚...
    茶點故事閱讀 45,033評論 2 355

推薦閱讀更多精彩內容

  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,166評論 25 707
  • Spring Cloud為開發(fā)人員提供了快速構建分布式系統中一些常見模式的工具(例如配置管理,服務發(fā)現激才,斷路器拓型,智...
    卡卡羅2017閱讀 134,659評論 18 139
  • <一>編寫Hello World React Native看起來很像React,只不過其基礎組件是原生組件而非we...
    AFinalStone閱讀 1,028評論 0 2
  • 近日瘸恼,湖南一16歲少年因抗拒作業(yè)而殘忍殺師劣挫。究竟是什么讓十六歲花一般的少年舉起刺刀殘忍的虐殺與自己朝夕相處的和藹可...
    寶拉羊閱讀 346評論 0 0
  • 近來压固,有朋友接連遇到不好的事。一個朋友媽媽得了癌癥靠闭,另一個朋友媽媽也得了癌癥帐我。看到第一個朋友為了救媽媽愧膀,傾了全副心...
    AllyHe閱讀 201評論 0 0