搜尋
首頁web前端前端問答react ajax開發用什麼

react ajax開發用什麼

Mar 21, 2022 pm 05:53 PM
ajaxreact

react ajax開發可以用:1、jQuery的「$.ajax」方法;2、Fetch API;3、SuperAgent,它是一個輕量級的AJAX API函式庫;4、Axios函式庫,主要是用於向後台發起請求的;5、Request庫。

react ajax開發用什麼

本教學操作環境: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 的。

然而,jQuery 是一個包含很多功能的大頭兒,只為了用一下 AJAX 功能而引入整個 jQuery 是沒有意義的(除非你還使用 jQuery 做了很多別的事情)。 So,用什麼才好?答案是

fetch API。

2、Fetch API

https://github.com/github/fetch

Fetch 是個新的、簡單的、標準化的API,旨在統一Web通訊機制,並取代XMLHttpRequest。它已經被主流瀏覽器所支持,針對較舊的瀏覽器也有了一個polyfill (Benz亂入:polyfill 直譯是填充工具,就是舊瀏覽器本來不支援某個新的JS API,引入一段js程式碼後就支持了,這一段js程式碼給舊瀏覽器」填入「了一個API。這個字我實在不知道怎麼翻譯,感覺反而保留原字不翻譯更能讓讀者理解。)。如果你在使用 Node.js ,你也可以透過 node-fetch 來讓 Node.js 支援 Fetch

若把上述用jQuery

$.ajax 的程式碼段改成fetch 實作的話,程式碼應該長這樣子:

loadCommentsFromServer: function() {
    fetch(this.props.url).then(function(response){
        // 在这儿实现 setState
    });
}

在一些流行的React 教學中你也許會發現

fetch 的身影。要了解更多關於fetch 的情況,可參考下列連結(全英文):

    #Mozilla
  • ##David Walsh Blog
  • Google Developers
  • WHATWG
3、SuperAgent

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 開發同構應用程式

(Benz 亂入:這個連結是我加的,旨在照顧初學者)

,你可以用webpack 之類的東西嵌入superagent 並讓它適用於瀏覽器端。因為瀏覽器端和伺服器端的 API 是一樣的,所以其 Node.js 版本不需要修改任何程式碼就可以在瀏覽器上執行。

4、Axios

https://github.com/axios/axios

Axios 是基於promise 物件

(Benz 亂入:這個連結也是我加的)

的HTTP 用戶端;axios主要是用來向後台發起請求的,還有在請求中做更多是可控功能。 。與 fetchsuperagent 一樣,它同時支援瀏覽器端和 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中文網其他相關文章!

陳述
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
React中的鑰匙:深入研究性能優化技術React中的鑰匙:深入研究性能優化技術May 01, 2025 am 12:25 AM

KeysinreactarecrucialforopTimizingPerformanceByingIneFefitedListupDates.1)useKeyStoIndentifyAndTrackListelements.2)避免使用ArrayIndi​​cesasKeystopreventperformansissues.3)ChooSestableIdentifierslikeIdentifierSlikeItem.idtomaintainAinainCommaintOnconMaintOmentStateAteanDimpperperFermerfermperfermerformperfermerformfermerformfermerformfermerment.ChosestopReventPerformissues.3)

反應中的鍵是什麼?反應中的鍵是什麼?May 01, 2025 am 12:25 AM

ReactKeySareUniqueIdentifiers usedwhenrenderingListstoimprovereConciliation效率。 1)heelPreactrackChangesInListItems,2)使用StableanDuniqueIdentifiersLikeItifiersLikeItemidSisRecumended,3)避免使用ArrayIndi​​cesaskeyindicesaskeystopreventopReventOpReventSissUseSuseSuseWithReRefers和4)

反應中獨特鍵的重要性:避免常見的陷阱反應中獨特鍵的重要性:避免常見的陷阱May 01, 2025 am 12:19 AM

獨特的keysarecrucialinreactforoptimizingRendering和MaintainingComponentStateTegrity.1)useanaturalAlaluniqueIdentifierFromyourDataiFabable.2)ifnonaturalalientedifierexistsistsists,generateauniqueKeyniqueKeyKeyLiquekeyperaliqeyAliqueLiqueAlighatiSaliqueLiberaryLlikikeuuId.3)deversearrayIndi​​ceSaskeyseSecialIndiceSeasseAsialIndiceAseAsialIndiceAsiall

將索引用作react中的鍵將索引用作react中的鍵May 01, 2025 am 12:17 AM

使用索引作為鍵在React中是可以接受的,但僅限於列表項順序不變且不會動態添加或刪除的情況;否則,應使用穩定且唯一的標識符作為鍵。 1)在靜態列表(如下拉菜單選項)中使用索引作為鍵是可以的。 2)如果列表項可以重新排序、添加或刪除,使用索引會導致狀態丟失和意外行為。 3)始終使用數據的唯一ID或生成的標識符(如UUID)作為鍵,以確保React正確更新DOM和維護組件狀態。

React的JSX語法:對UI設計的開發人員友好方法React的JSX語法:對UI設計的開發人員友好方法May 01, 2025 am 12:13 AM

jsxisspecialbecialbecapeitblendshtmlwithjavascript,enableComponent-lase-uidesign.1)itallowsembeddingjavascriptInhtml-likesyntax,EnhancinguidesignAndLogicIntegration.2)

使用HTML5可以播放哪種類型的音頻文件?使用HTML5可以播放哪種類型的音頻文件?Apr 30, 2025 pm 02:59 PM

本文討論了HTML5音頻格式和跨瀏覽器兼容性。它涵蓋MP3,WAV,OGG,AAC和WebM,並建議使用多個來源和後備以實現更廣泛的可訪問性。

SVG和Canvas HTML5元素之間的區別?SVG和Canvas HTML5元素之間的區別?Apr 30, 2025 pm 02:58 PM

SVG和畫布是Web圖形的HTML5元素。基於向量的SVG擅長可擴展性和交互性,而基於像素的畫布則更適合遊戲等性能密集型應用程序。

使用HTML5可能會拖放嗎?使用HTML5可能會拖放嗎?Apr 30, 2025 pm 02:57 PM

HTML5可以通過特定的事件和屬性進行拖放,從而允許自定義,但面臨舊版本和移動設備上的瀏覽器兼容性問題。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

MantisBT

MantisBT

Mantis是一個易於部署的基於Web的缺陷追蹤工具,用於幫助產品缺陷追蹤。它需要PHP、MySQL和一個Web伺服器。請查看我們的演示和託管服務。

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)