五分鐘學習React(五):React兩種構建應用方式選擇

来源:https://www.cnblogs.com/eason-peng/archive/2018/01/19/8315185.html
-Advertisement-
Play Games

經過這四期的講解,我們從Hello World應用入手,解釋了React最重要的概念JSX,以及兩種不同模式的應用構建方法。這一講我們著重對比傳統模式和新模式下的React項目構建,從而為初學者提供學習方向。 1. 傳統模式構建 一般在傳統模式下,我們構建前端項目很簡單。就是下載各種js文件,如JQ ...


經過這四期的講解,我們從Hello World應用入手,解釋了React最重要的概念JSX,以及兩種不同模式的應用構建方法。這一講我們著重對比傳統模式和新模式下的React項目構建,從而為初學者提供學習方向。

1. 傳統模式構建

一般在傳統模式下,我們構建前端項目很簡單。就是下載各種js文件,如JQuery、Echart等,直接放置在html靜態文件。這樣在這個前端項目中,預設生成或者是定義全局變數,從而使用js各種開發包的特性。典型代碼如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    ...
    <script type="text/javascript" src="js/jquery-2.1.1.min.js"></script>>
    ...
</head>
<body>
    ...
    <script type="text/javascript">
    $("div.test").onclick(function(){
        // code goes ...
    })
    </script>
</body>
</html>

這種方法構建的前端項目,顯而易見很迅速,可以簡單、直接的完成前端想要的各種邏輯。比如,我要控制一個div的顯示,直接通過Jquery的selector操作,就可以完成。為了符合眾多前端er的習慣,React也提供了類似的方案,可以說這個對於初學React的朋友來說非常方便。

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8" />
    <title>Hello World</title>
    <script src="scripts/react.development.js"></script>
    <script src="scripts/react-dom.development.js"></script>
    <script src="scripts/babel.min.js"></script>
</head>

<body>
    <div id="root"></div>
    <script type="text/babel">

      ReactDOM.render(
        <h1>Hello, world!</h1>,
        document.getElementById('root')
      );

    </script>
</body>

</html>

而然隨著互聯網的發展,越來越多的網站開始變得臃腫、龐大,諸如淘寶網、facebook網站的邏輯相當複雜。對於網站處理邏輯非常繁多,漸漸地使用傳統模式構建,會使項目難以更新feature,尋找bug也會非常麻煩。項目的更新、維護,對於團隊的壓力可想而知。因此,目前前端界的共識是使用Webpack+babel的構建模式。

2. Webpack+babel模式構建

隨著JavaScript語言下一代標準的愈發成熟,ES6,即ECMAScript2015(ES2015)受到越來越多的開發者歡迎。為了彌補當前瀏覽器不支持ES6的缺陷,babel孕育而生,它是JavaScript的一個編譯器,是用戶能夠在瀏覽器中體驗下一代JavaScript語言的魅力。Webpack則是JavaScript中比較知名的打包工具。這兩個構建工具構成了React應用快速搭建的基礎。

React官方將這兩個工具封裝在了名為create-react-app的腳手架中,按照官網的說法,create-react-app適合搭建單頁面應用[詳細信息]

初學React的小白用戶,可以使用簡單的指令,它將啟動webpack-dev-server的HTTP Server。在這個伺服器中,提供了babel的配置。

npx create-react-app my-app
cd my-app
npm start

npx為一個類似npm的cli工具,目的是管理本地的第三方工具集[介紹]

由於create-react-app提供了良好的封裝,這些服務啟動的過程,使用者是無法察覺的。要瞭解create-react-app啟動的全工程,用戶可以從這個教程瞭解。

當然create-react-app也提供了用戶自定義的webpack和babel配置。只要輸入下列指令(該指令不可逆):

npm run eject

3. 總結

對比兩種不同的React構建方法,使用的目的也不一樣。第一種方法提供了更為靈活多變的應用特效方案,適應於展示特效多的應用,如小游戲、H5廣告等。而第二種方法適用於構建中大型Web app應用。

對於前端學習者來說,推薦使用第二種方法,畢竟這屬於目前前端的趨勢。有利於開發者適應大規模開發。潛臺詞就是更容易在大廠商找到工作!!!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 1.顯示當前運行的全部模擬器: adb devices2.啟動ADB adb start-server3.停止ADB adb kill-server4.安裝應用程式: adb install -r [apk文件]-l #鎖定該程式-r #重新安裝該程式,保存數據-s #安裝在SD卡內,而不是設備內部 ...
  • 本文主要轉載自:Objective-C-Coding-Guidelines-In-Chinese Objective-C編碼規範,內容來自蘋果、谷歌的文檔翻譯,自己的編碼經驗和對其它資料的總結。 一 概要 Objective-C是一門面向對象的動態編程語言,主要用於編寫iOS和Mac應用程式。關於O ...
  • 1 網路請求的安全方案 1.1 https請求,最好有安全交互平臺。 1.2 對重要的參數請求進行加密(推薦AES,ERSA加密)。 1.3 伺服器返回數據時,對重要數據進行加密。 1.4 不要把密鑰寫到代碼里。可以先通過非對稱加密的介面獲取密鑰,然後再在後面的介面通信中用這個密鑰進行加密。 1.5 ...
  • 一、運行的效果圖 1、剛開始的效果 2、運行結束後的效果 二、準備工作 1、準備一個html文件導入到oc工程中 2、jiaohu.html文件的原始內容 3、從oc語言中操作.html文件---增刪改查 1).查詢操作 2).刪除操作 3).更改操作 4).插入操作 //插入操作1 //插入操作2 ...
  • 開發過程中出現了通過自定義設置打開熱點後手機搜索不到熱點的問題。 後來通過觀看 /data/misc/wifi 目錄下的 hostapd.conf 文件,發現是 ...
  • speed-tools 是一款基於代理模式的動態部署apk熱更新框架、插件化開發框架; ...
  • 1、讀取通信錄 1)、9.0以前:AddressBook 2)、9.0以後:Contacts 2、調用通信錄UI(不弄) 1)、9.0以前:AddressBookUI 2)、9.0以後:ContactsUI 3、參考 0、寫在前面 1)、plist 需要設置 隱私許可權描述 NSContactsUsa ...
  • 我新建了一個web前端的新手交流群,包括基礎知識和剛入職的技術分享,人還不多,期待著每一個人的加入,希望可以得到你的認同哦~你的加入是我組織交流群的一大動力哦!~ web前端交流QQ群:314439765 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...