<React Native移動開發實戰>-1-React Native的JSX解決方案

来源:http://www.cnblogs.com/mochou/archive/2017/08/02/7276904.html
-Advertisement-
Play Games

JSX並不是一門新的開發語言,而是Facebook提出的語法方案:一種可以在JavaScript代碼中直接書寫HTML標簽的語法糖,所以,JSX本質上還是JavaScript語言。 ...


   JSX並不是一門新的開發語言,而是Facebook提出的語法方案:一種可以在JavaScript代碼中直接書寫HTML標簽的語法糖,所以,JSX本質上還是JavaScript語言。

小知識:語法糖(Syntactic sugar)是由英國計算科學家彼得·蘭丁(https://zh.wikipedia.org/ wiki/%E5%BD%BC%E5%BE%97%C2%B7%E5%85%B0%E4%B8%81)發明的一個術語,指電腦語言中添加的某種語法,這種語法對語言的功能並沒有影響,但是更方便程式員使用。語法糖讓程式更加簡潔,有更高的可讀性。

在React和React Native開發中,不一定非要使用JSX,也可以直接使用JavaScript進行開發。但是,強烈建議讀者使用JSX!因為JSX在定義類似HTML這種樹形結構時,簡單明瞭,極大地提高了開發和維護的效率。

下麵以1.4節第一個React Native應用中的代碼為例:

 

01  export default class ch02 extends Component { // 每個頁面可以理解成一個組件

02      render() {                                  // 渲染頁面的函數

03          return (

04              <View style={styles.container}>    // 頁面根View

05                  <Text style={styles.welcome}>

06                      Welcome to React Native!

07                  </Text>

08                  <Text style={styles.instructions}>

09                      To get started, edit index.ios.js

10                  </Text>

11                  <Text style={styles.instructions}>

12                      Press Cmd+R to reload,{'\n'}

13                      Cmd+D or shake for dev menu

14                  </Text>

15              </View>

16          );

17      }

16  }

  

在上述代碼中,組件的render()方法函數是用於渲染頁面的,它的返回值是一個View的對象,但是為什麼沒有發現創建對象和設置屬性的代碼呢?原來,JSXTransformer幫我們把代碼中XML-Like語法編譯轉換成真實可用的JavaScript代碼,它不僅僅創建View對象、設置View樣式和佈局,同時更加貼心的是,還構建了View之間的樹形結構。例如,上述例子中的樹形結構是這樣的:

 Root View (style container)

---- Sub Text 1 (style welcome)

---- Sub Text 2 (style instructions)

---- Sub Text 3 (style instructions)

  

和我一起學吧,《React Native移動開發實戰》

 


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

-Advertisement-
Play Games
更多相關文章
  • 新特性:模板字元串 傳統字元串 es6簡潔的字元串拼接 對比兩段拼接的代碼,模板字元串使得我們不再需要反覆使用雙引號(或者單引號)了;而是改用反引號標識符(`),插入變數的時候也不需要再使用加號(+)了,而是把變數放入${ }即可。 使用時要註意 1、可以定義多行字元串 傳統的多行字元串寫法: 模板 ...
  • 1.內容在一屏內顯示的,採用了(內容框)上下左右居中的辦法,裡面的內容絕對於這個內容框定位.這樣一來,在不同大小屏中,內容總是在中間,看起來較正常 2.長,寬,LEFT,TOP,RIGHT,BOTTOM都採用了REM,並且HTML的FONT-SIZE設置的是100PX一是覺得計算方便,二是如果設為1 ...
  • sass文件轉css時註釋雖然支持中文,但是出現亂碼的解決方法 Scss 註釋中文報錯問題(windows系統, 已解決)找到ruby的安裝目錄,裡面也有sass模塊,類似這樣樣的路徑:F:\Program Files (x86)\Ruby24-x64\lib\ruby\gems\2.4.0\gem ...
  • 表格佈局tabelLayout 一、簡介 二、實例 ...
  • 框架佈局FrameLayout 一、簡介 二、代碼實例 結果圖: 代碼: 需要註意的代碼: framelayoutfry2.MainActivity /Test_FrameLayout/res/layout/activity_main.xml ...
  • Windows下的Android遠程桌面助手(Android Remote Displayer and Controller),增加了錄製視頻功能,突破了Android原生180S的限制。 ...
  • 程式猿是否應該接私活? 我大約從去年 11 月份開始接私活做,到目前為止也有大半年了。自己在這大半年的時間里,也學習了很多,在此記錄一下這大半年來的感受以及一些不成熟的建議。 在我看來,在你又打算接私活的時候,你應該考慮以下幾個問題 時間是否充裕? 個人認為這個問題非常重要,如果時間不夠充裕的話,接 ...
  • Coundn't load memtrack module (No such file or directory) 去仔細看日誌,是包名有問題 一、出現癥狀 提示找logcat logcat裡面發現Coundn't load memtrack module (No such file or dire ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...