React 入門學習筆記整理(二)—— JSX簡介與語法

来源:https://www.cnblogs.com/fangnianqin/archive/2018/12/18/10137059.html
-Advertisement-
Play Games

先看下這段代碼: 解析: 1、JSX全稱JavaScript XML,在js中寫XML標簽,是javascript的一種擴展語法。JSX標簽語法既不是字元串也不是 HTML,在編譯之後,JSX 其實會被轉化為普通的 JavaScript 對象,描述要顯示的UI信息。 JSX的編譯過程如圖所示: 2、 ...


先看下這段代碼:

import React from 'react';
//最終渲染需要調用ReactDOM庫,將jsx渲染都頁面中
import ReactDOM from 'react-dom';
import * as serviceWorker from './serviceWorker';

let h = <React.Fragment>
    <h2>hello</h2>
    <ul></ul>
    </React.Fragment>

//把第一個參數的結構渲染到root標簽中
ReactDOM.render(h, document.getElementById('root'));

serviceWorker.unregister();

解析:

1、JSX全稱JavaScript XML,在js中寫XML標簽,是javascript的一種擴展語法。JSX標簽語法既不是字元串也不是 HTML,在編譯之後,JSX 其實會被轉化為普通的 JavaScript 對象,描述要顯示的UI信息。
JSX的編譯過程如圖所示:

2、jsx語法
1)JSX 可以當做值賦值給變數

let h =(
    <div>
        <h2>hello</h2>
        <span>React</span>
    </div>
);
ReactDOM.render(h, document.getElementById('root'));

2)可以當做函數的返回值

function createH(){
    return <React.Fragment>
        <h2>hello</h2>
        <ul></ul>
    </React.Fragment>
}
ReactDOM.render(createH(), document.getElementById('root'));

3)也可以存在數組中

let arr = [
    <h2 key="111">hello</h2>,
    <ul key="222"></ul>,
]
ReactDOM.render(arr, document.getElementById('root'));

數組中如果不寫key,控制台將會輸出如下警告信息:

4)JSX 當中使用 JavaScript 表達式,要包括在大括弧里。在 JSX 代碼的外面擴上一個小括弧,這樣可以防止 分號自動插入 的 bug。

function formatName(user) {
    return user.name + ' ' + user.date;
}
const user = {
    name:'kristy',
    date:'2018-12-18'
};
let value  = 'hello';
let h = (
    <div>
        <h2>{value}</h2>
        <span>{formatName(user)}</span>
    </div>
);

其他詳細的介紹:https://react.docschina.org/docs/introducing-jsx.html


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

-Advertisement-
Play Games
更多相關文章
  • 本次給大家分享一篇node.js通過axios實現網路請求的方法,寫的十分的全面細緻,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。 1、使用Npm 下載axios npm install --save axios 上述的方法請求文件時候,body的預設格式不是fo ...
  • 這篇文章主要介紹了react-redux中connect的裝飾器用法@connect詳解,寫的十分的全面細緻,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。 通常我們需要一個reducer和一個action,然後使用connect來包裹你的Component。假設你 ...
  • 本次為大家分享一篇解決vue多個路由共用一個頁面的問題,寫的十分的全面細緻,具有一定的參考價值,對此有需要的朋友可以參考學習下。如有不足之處,歡迎批評指正。 在日常的vue開發中我們可能會遇見多個路由需要共用一個頁面的需求,特別是當路由是通過動態添加的,不同的路由展示的東西只是數據不同其他沒有變化。 ...
  • 偽類after、before的使用 ::before//偽元素 :hover//偽類 #all::after{ display:table; clear:both; content:""; } #all::after:在all裡面的最後添加一個虛擬的子元素after a:hover:帶偽類別的a標簽 ...
  • 最近在學習JavaScript基礎,在學習到面向對象編程時,學習到在JavaScript中實現模塊化的方法,其中一個重要的點是如何封裝私有變數。 實現封裝私有變數的方法主要是: 在立即執行函數中,重點在於createStringBuilder這個函數,這個函數實現了內外對接的介面,對內保護了Stri ...
  • 111 ...
  • 居然第一次遇到這種問題,還想了半天到底是怎麼回事,為什麼明明div設置寬度了,裡面的文字超過寬度後居然不換行。 (1)word-break屬性,可以讓瀏覽器實現在任意位置換行。 normal:使用瀏覽器預設的換行規則 break-all:允許在單詞內換行,效果如下: keep-all:只能在半形空格 ...
  • 需要在最後重置一下輪播 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...