react ajax開發可以用:1、jQuery的「$.ajax」方法;2、Fetch API;3、SuperAgent,它是一個輕量級的AJAX API函式庫;4、Axios函式庫,主要是用於向後台發起請求的;5、Request庫。
本教學操作環境:Windows7系統、react17.0.1版、Dell G3電腦。
React AJAX 請求的5種方案
1、jQuery $.ajax
這是一個快速又粗的方案。在舊版的官方 React 教學(official React tutorial)中,他們使用了 jQuery $.ajax
來示範如何從伺服器取得資料。如果你是剛開始學習和把玩 React,jQuery 可以節省你大量入門和開發的時間,因為我們都對 jQuery 非常熟悉了。這是jQuery 實作AJAX 的範例:
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) }); }
P.S. 這程式碼段摘自舊版的官方教學
##這裡示範如何在一個React 元件裡面使用jQuery 的$.ajax。唯一要注意的是如何在
success 回呼裡面呼叫
this.setState() ,即當 jQuery 成功收到資料之後應該如何透過 React 的 API 更新 state 的。
fetch API。
2、Fetch API
https://github.com/github/fetchFetch 是個新的、簡單的、標準化的API,旨在統一Web通訊機制,並取代
XMLHttpRequest。它已經被主流瀏覽器所支持,針對較舊的瀏覽器也有了一個polyfill
(Benz亂入:polyfill 直譯是填充工具,就是舊瀏覽器本來不支援某個新的JS API,引入一段js程式碼後就支持了,這一段js程式碼給舊瀏覽器」填入「了一個API。這個字我實在不知道怎麼翻譯,感覺反而保留原字不翻譯更能讓讀者理解。)。如果你在使用 Node.js ,你也可以透過 node-fetch 來讓 Node.js 支援 Fetch。
$.ajax 的程式碼段改成
fetch 實作的話,程式碼應該長這樣子:
loadCommentsFromServer: function() { fetch(this.props.url).then(function(response){ // 在这儿实现 setState }); }在一些流行的React 教學中你也許會發現
fetch 的身影。要了解更多關於
fetch 的情況,可參考下列連結(全英文):
- #Mozilla
- ##David Walsh Blog
- Google Developers
- WHATWG
https://github.com/visionmedia/superagent
SuperAgent 是一個輕量級的AJAX API 函式庫,為更好的可讀性和靈活性而生。如果某些原因讓你不太想用
fetch,那麼 SuperAgent 就幾乎是必然的選擇了。 SuperAgent 的用法大概是這樣的:<pre class='brush:php;toolbar:false;'>loadCommentsFromServer: function() {
request.get(this.props.url).end(function(err,res){
// 在这儿实现 setState
});
}</pre>
SuperAgent 也有 Node.js 版本,API 是一樣的。如果你在用Node.js 和React 開發同構應用程式
,你可以用webpack 之類的東西嵌入superagent 並讓它適用於瀏覽器端。因為瀏覽器端和伺服器端的 API 是一樣的,所以其 Node.js 版本不需要修改任何程式碼就可以在瀏覽器上執行。
https://github.com/axios/axios
Axios 是基於promise 物件
(Benz 亂入:這個連結也是我加的)的HTTP 用戶端;axios主要是用來向後台發起請求的,還有在請求中做更多是可控功能。 。與 fetch 和 superagent
一樣,它同時支援瀏覽器端和 Node.js 端。另外你可以在其 Github 主頁上發現,它有很多很實用的高級功能。 這是Axios 的大概用法:
loadCommentsFromServer: function() { axios.get(this.props.url).then(function(response){ // 在这儿实现 setState }).catch(function(error){ // 处理请求出错的情况 }); }5、Request
https://github.com/request/request
#若不介紹這個request 函式庫,感覺上本文會不太完整。這是一個在思想上追求極簡設計的JS庫,在 Github 上擁有超過 12k 的 star
(Benz 亂入:我翻譯這篇文章時已經 16k star 了)。它也是最受歡迎的 Node.js 模組之一。進入它的 GitHub 主頁 了解更多。 用法範例:
loadCommentsFromServer: function() { request(this.props.url, function(err, response, body){ // 在这儿实现 setState }); }
【相關推薦:
Redis影片教學以上是react ajax開發用什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

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

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

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


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

SublimeText3 Linux新版
SublimeText3 Linux最新版

WebStorm Mac版
好用的JavaScript開發工具

Dreamweaver CS6
視覺化網頁開發工具

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

SublimeText3漢化版
中文版,非常好用