react ajax 開発で使用できるもの: 1. jQuery の "$.ajax" メソッド; 2. API の取得; 3. 軽量の AJAX API ライブラリである SuperAgent; 4. Axios ライブラリ (主にリクエストの開始に使用されます)背景; 5. ライブラリをリクエストします。
このチュートリアルの動作環境: Windows7 システム、react17.0.1 バージョン、Dell G3 コンピューター。
React AJAX リクエストに対する 5 つのソリューション
1. jQuery $.ajax
これは、簡単かつ大雑把なソリューションです。公式 React チュートリアルの古いバージョンでは、サーバーからデータを取得する方法を示すために jQuery $.ajax
を使用していました。 React を学び始めたばかりの場合、jQuery を使用すると、開発の開始と開発にかかる時間を大幅に節約できます。これは、誰もが jQuery に精通しているためです。これは、AJAX を実装する jQuery の例です:
loadCommentsFromServer: function() { $.ajax({ url: this.props.url, dataType: 'json', cache: false, success: function(data) { this.setState({data: data}); // 注意这里 }.bind(this), error: function(xhr, status, err) { console.error(this.props.url, status, err.toString()); }.bind(this) }); }
PS. このコード スニペットは、公式チュートリアルの古いバージョンから抜粋したものです
これは、jQuery を AJAX で使用する方法を示しています。 React コンポーネント$.ajax
。注意が必要な唯一のことは、success
コールバックで this.setState()
を呼び出す方法、つまり、jQuery がデータを正常に受信した後に React API を通じて状態を更新する方法です。 。
ただし、jQuery は多くの関数を含む大きなものであり、AJAX 関数を使用するためだけに jQuery 全体を導入するのは意味がありません (jQuery を他の多くのことにも使用する場合を除く)。それで、何を使えばいいのでしょうか?答えは fetch
API です。
2. Fetch API
https://github.com/github/fetch
Fetch
は新しく、シンプルです、Web 通信メカニズムを統合し、XMLHttpRequest
を置き換えるように設計された標準化された API。これは主流のブラウザでサポートされており、古いブラウザ用のポリフィル もあります (ベンツ カオス: ポリフィルは文字通り塗りつぶしツールを意味します。つまり、古いブラウザは元々新しい JS API をサポートしておらず、一部の JS コードを導入しています)後でサポートされます。この js コードは、古いブラウザーの API を「埋めます」。この単語をどう訳せばいいのかわかりませんが、元の単語を翻訳せずに残しておくと、読者が理解しやすくなるような気がします。 ) 。 Node.js を使用している場合は、Node.js がノードフェッチを通じて Fetch
をサポートできるようにすることもできます。
jQuery $.ajax
を使用した上記のコード セグメントを fetch
に変更すると、コードは次のようになります。
loadCommentsFromServer: function() { fetch(this.props.url).then(function(response){ // 在这儿实现 setState }); }
fetch
は人気のある React チュートリアルで見つかるかもしれません。 fetch
の詳細については、次のリンク (すべて英語) を参照してください:
- Mozilla
- David Walsh Blog
- Google Developers
- WHATWG
3、SuperAgent
https://github.com/visionmedia/superagent
SuperAgent は、読みやすさと柔軟性を高めるために生まれた軽量の AJAX API ライブラリです。何らかの理由で fetch
を使用したくない場合は、SuperAgent を選択することはほぼ避けられません。 SuperAgent の使用法は大まかに次のとおりです。
loadCommentsFromServer: function() { request.get(this.props.url).end(function(err,res){ // 在这儿实现 setState }); }
SuperAgent には Node.js バージョンもあり、API は同じです。 Node.js と React を使用して同型アプリケーションを開発している場合 (ベンツの混乱: このリンクは初心者のために私が追加したものです)、webpack のようなものを使用して superagent # を埋め込むことができます## そしてブラウザ側で動作するようにします。ブラウザ側とサーバー側の API は同じであるため、Node.js バージョンはコードを変更せずにブラウザ上で実行できます。
4、Axios
https://github.com/axios/axiosAxios は Promise ベースのオブジェクトです(Benz intrusion : このリンクも私によって追加されました) HTTP クライアント; axios は主にバックグラウンドへのリクエストを開始するために使用され、リクエストにはさらに制御可能な機能があります。 。 fetch や
superagent と同様に、ブラウザ側と Node.js 側の両方をサポートします。さらに、Github ホームページには、多くの便利な高度な機能があることがわかります。
loadCommentsFromServer: function() { axios.get(this.props.url).then(function(response){ // 在这儿实现 setState }).catch(function(error){ // 处理请求出错的情况 }); }
5、リクエスト
https://github.com/request/requestこのリクエストライブラリを紹介しないとこの記事が不完全になってしまう気がします。これは、イデオロギーにおけるミニマリスト デザインを追求する JS ライブラリで、Github で 12,000 個以上のスター
を獲得しています (ベンツはめちゃくちゃです。この記事を翻訳した時点ではすでに 16,000 個のスターがありました) 。これは、最も人気のある Node.js モジュールの 1 つでもあります。詳細については、GitHub ホームページにアクセスしてください。
使用例:loadCommentsFromServer: function() { request(this.props.url, function(err, response, body){ // 在这儿实现 setState }); }[関連する推奨事項:
Redis ビデオ チュートリアル]
以上がReact Ajax 開発に何を使用するかの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

在react中,canvas用于绘制各种图表、动画等;可以利用“react-konva”插件使用canvas,该插件是一个canvas第三方库,用于使用React操作canvas绘制复杂的画布图形,并提供了元素的事件机制和拖放操作的支持。

在react中,antd是基于Ant Design的React UI组件库,主要用于研发企业级中后台产品;dva是一个基于redux和“redux-saga”的数据流方案,内置了“react-router”和fetch,可理解为应用框架。

React不是双向数据流,而是单向数据流。单向数据流是指数据在某个节点被改动后,只会影响一个方向上的其他节点;React中的表现就是数据主要通过props从父节点传递到子节点,若父级的某个props改变了,React会重渲染所有子节点。

因为在react中需要利用到webpack,而webpack依赖nodejs;webpack是一个模块打包机,在执行打包压缩的时候是依赖nodejs的,没有nodejs就不能使用webpack,所以react需要使用nodejs。

在react中,forceupdate()用于强制使组件跳过shouldComponentUpdate(),直接调用render(),可以触发组件的正常生命周期方法,语法为“component.forceUpdate(callback)”。

react是组件化开发;组件化是React的核心思想,可以开发出一个个独立可复用的小组件来构造应用,任何的应用都会被抽象成一颗组件树,组件化开发也就是将一个页面拆分成一个个小的功能模块,每个功能完成自己这部分独立功能。

react与vue的虚拟dom没有区别;react和vue的虚拟dom都是用js对象来模拟真实DOM,用虚拟DOM的diff来最小化更新真实DOM,可以减小不必要的性能损耗,按颗粒度分为不同的类型比较同层级dom节点,进行增、删、移的操作。

react和reactdom的区别是:ReactDom只做和浏览器或DOM相关的操作,例如“ReactDOM.findDOMNode()”操作;而react负责除浏览器和DOM以外的相关操作,ReactDom是React的一部分。


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

SublimeText3 Linux 新バージョン
SublimeText3 Linux 最新バージョン

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

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

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