五分鐘學習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
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...