React Native で Fetch を使用してネットワーク リクエストを送信する方法
この記事では主に、Fetch を使用してネットワーク リクエストを送信する React Native のサンプル コードを紹介します。興味のある方は参考にしてください。私たちのプロジェクトでは、HTTP (HTTPS) リクエストを使用してネットワークにアクセスすることがよくあります。通常は「GET」、「PUT」、「POST」、「DELETE」に分かれています。指定しない場合、デフォルトは GET リクエストです。
プロジェクトでは、通常、GET と POST の 2 つのリクエスト メソッドを使用します。パラメーターを含むフォームを通じて送信されるリクエストには、通常、POST リクエスト メソッドを使用します。
HTTP リクエストを行うには、React Native が提供する Fetch API を使用する必要があります。任意のアドレスからコンテンツを取得するには、URL をパラメーターとして fetch メソッドに渡すだけです (「fetch」という言葉自体は
GETを取得することを意味します) GET メソッドを通じてデータをリクエストする場合、JSON への変換は次の方法で実現できます。以下のコード:
fetch('https://facebook.github.io/react-native/movies.json') .then((response) => response.json()) .then((responseJson) => { return responseJson.movies; }) .catch((error) => { console.error(error); });
上記のリクエストで返されたResponseをJSONオブジェクトに変換し、JSONオブジェクト内のmovieフィールドを取り出します。同時に、ネットワーク障害やアクセス接続エラーなどのエラーが発生した場合、通常の状況では、次の結果が得られます:
{ "title": "The Basics - Networking", "description": "Your app fetched this from a remote endpoint!", "movies": [ { "title": "Star Wars", "releaseYear": "1977"}, { "title": "Back to the Future", "releaseYear": "1985"}, { "title": "The Matrix", "releaseYear": "1999"}, { "title": "Inception", "releaseYear": "2010"}, { "title": "Interstellar", "releaseYear": "2014"} ] }
もちろん、上記は最も基本的な GET リクエストであり、Fetch にはオプションの 2 番目のパラメータもあります。 HTTP リクエストの一部のパラメーターをカスタマイズするために使用されます。ヘッダー パラメーターを指定したり、POST メソッドの使用を指定したり、データを送信したりできます。フェッチ API は、ヘッダーのカスタマイズ、メソッドの変更、ボディの追加などもサポートしています。上記の基本的な POST リクエスト、独自のヘッダー (Accept と Content-Type) を追加し、
POST (2)let url = "http://www.yousite.com/xxxx.ashx” let params = {"name":"admin","password":"admin"}; fetch(url, { method: 'POST', headers: { 'Accept': 'application/json', 'Content-Type': 'application/json', }, body: JSON.stringify(params) })
POST (3) を追加します。上記の 2 つのメソッドを通じて、 POST リクエストを送信する方法もあります。もちろん、この方法も推奨されます
サーバーが上記の POST データ形式を認識できない場合は、次のような例を試してください:let url = "http://www.yousite.com/xxxx.ashx”; let params = "username=admin&password=admin”; fetch(url, { method: 'POST', headers: { 'Content-Type': 'application/x-www-form-urlencoded' }, body: params, }).then((response) => { if (response.ok) { return response.json(); } }).then((json) => { console.log(json) }).catch((error) => { console.error(error); });
let REQUEST_URL = 'http://www.yousite.com/xxxx.ashx'; // `首先我们需要自己创建一个FormData,来存请求参数` let parameters = new FormData(); parameters.append("mt", "30013"); parameters.append("pg", "1"); parameters.append('ps', '20'); fetch(REQUEST_URL, { method: 'POST', body: parameters }).then( (result) => { if (result.ok) { console.log(result) result.json().then( (obj) => { console.log(obj) } ) } } ).catch((error) => { console.log(error) Alert.alert('Error') })
サーバーの応答データを処理する
多くの場合、リクエストを開始するには、サーバーから返されたデータを処理する必要があります。ネットワーク リクエストは、当然、Promise を返します。このモードでは、非同期スタイルのコードを参照してください。 to: Promise
サーバーから返されたデータの処理。特定のコードについては、上記の実装コードを参照してください。 デフォルトでは、iOS はすべてのリクエストをブロックします。これは http プロトコルであるため、まず App Transport Security の例外を追加する必要があります
での Flux の実装方法をまとめました。 knockoutjs
vueを使用してシームレスなスクロールコンポーネントを実装する方法 JavaScript配列操作の難しさ(詳細なチュートリアル)
以上がReact Native で Fetch を使用してネットワーク リクエストを送信する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











React フロントエンドとバックエンドの分離ガイド: フロントエンドとバックエンドの分離と独立したデプロイメントを実現する方法、特定のコード例が必要です 今日の Web 開発環境では、フロントエンドとバックエンドの分離がトレンドになっています。フロントエンド コードとバックエンド コードを分離することで、開発作業がより柔軟かつ効率的になり、チームのコラボレーションが促進されます。この記事では、React を使用してフロントエンドとバックエンドの分離を実現し、それによって分離と独立したデプロイの目標を達成する方法を紹介します。まず、フロントエンドとバックエンドの分離とは何かを理解する必要があります。従来の Web 開発モデルでは、フロントエンドとバックエンドが結合されています。

React と RabbitMQ を使用して信頼性の高いメッセージング アプリケーションを構築する方法 はじめに: 最新のアプリケーションは、リアルタイム更新やデータ同期などの機能を実現するために、信頼性の高いメッセージングをサポートする必要があります。 React はユーザー インターフェイスを構築するための人気のある JavaScript ライブラリであり、RabbitMQ は信頼性の高いメッセージング ミドルウェアです。この記事では、React と RabbitMQ を組み合わせて信頼性の高いメッセージング アプリケーションを構築する方法を紹介し、具体的なコード例を示します。 RabbitMQ の概要:

ReactRouter ユーザーガイド: フロントエンドルーティング制御の実装方法 シングルページアプリケーションの人気に伴い、フロントエンドルーティングは無視できない重要な部分になりました。 React エコシステムで最も人気のあるルーティング ライブラリとして、ReactRouter は豊富な機能と使いやすい API を提供し、フロントエンド ルーティングの実装を非常にシンプルかつ柔軟にします。この記事では、ReactRouter の使用方法と具体的なコード例を紹介します。 ReactRouter を最初にインストールするには、次のものが必要です

PHP、Vue、React: 最適なフロントエンド フレームワークを選択するには?インターネット技術の継続的な発展に伴い、フロントエンド フレームワークは Web 開発において重要な役割を果たしています。 PHP、Vue、React は 3 つの代表的なフロントエンド フレームワークであり、それぞれに独自の特徴と利点があります。使用するフロントエンド フレームワークを選択するとき、開発者はプロジェクトのニーズ、チームのスキル、個人の好みに基づいて情報に基づいた決定を下す必要があります。この記事では、PHP、Vue、React の 3 つのフロントエンド フレームワークの特徴と用途を比較します。

Java フレームワークと React フレームワークの統合: 手順: バックエンド Java フレームワークをセットアップします。プロジェクト構造を作成します。ビルドツールを設定します。 React アプリケーションを作成します。 REST API エンドポイントを作成します。通信メカニズムを構成します。実際のケース (SpringBoot+React): Java コード: RESTfulAPI コントローラーを定義します。 React コード: API によって返されたデータを取得して表示します。

React を使用して応答性の高いバックエンド管理システムを開発する方法 インターネットの急速な発展に伴い、日々の業務を処理するために効率的で柔軟で管理が容易なバックエンド管理システムを必要とする企業や組織が増えています。現在最も人気のある JavaScript ライブラリの 1 つである React は、ユーザー インターフェイスを構築するための簡潔で効率的かつ保守しやすい方法を提供します。この記事では、React を使用して応答性の高いバックエンド管理システムを開発する方法と、具体的なコード例を紹介します。まず React プロジェクトを作成します

VUE.JSは、中小規模のプロジェクトや迅速な反復に適していますが、Reactは大規模で複雑なアプリケーションに適しています。 1)Vue.jsは使いやすく、チームが不十分な状況やプロジェクトスケールが小さい状況に適しています。 2)Reactにはより豊富なエコシステムがあり、高性能で複雑な機能的ニーズを持つプロジェクトに適しています。

React には、イベント処理関数、useEffect や useCallback、上位コンポーネントなどのクロージャがあります。詳細な紹介: 1. イベント処理関数のクロージャ: React では、コンポーネント内でイベント処理関数を定義すると、関数はクロージャを形成し、コンポーネントのスコープ内のステータスとプロパティにアクセスできます。このようにして、コンポーネントの状態とプロパティをイベント処理関数で使用して対話型ロジックを実装できます; 2. useEffect や useCallback のクロージャなど。
