26 JSX深度剖析與使用技巧

React對JSX的處理

React.createElement有三個參數:標簽類型,屬性集合,子元素
JSX其實是React.createElement函數調用的語法糖
JSX → 編譯 → React.createElement調用形式

class App extends React.Component {render() {return (<div className="box" id="J_Box"><h1 className="title">This is a <span>TITLE</span></h1></div>)}
}
ReactDOM.render(<App />,document.getElementById('app')
)

在這里插入圖片描述

class App extends React.Component {render() {return /* @__PURE__ */ React.createElement("div", {className: "box",id: "J_Box"}, /* @__PURE__ */ React.createElement("h1", {className: "title"}, "This is a ", /* @__PURE__ */ React.createElement("span", null, "TITLE")));}
}

React元素類型

  • MyButton → 是React元素 → 也是React元素類型
  • 以JSX形式使用組件,則該組件必須存在于當前作用域
  • React.createElement拿到組件并實例化,拿到他的視圖

如何在JSX中使用點語法

const colorSystem = {danger: 'red',info: 'gray',primary: 'blue',warning: 'orange'
}
const MyUI = {Button: class extends React.Component {render() {const { type, children } = this.propsreturn (<buttonstyle={{color: '#fff',backgroundColor: colorSystem[type]}}>{children}</button>)}}
}
class App extends React.Component {render() {return (<><MyUI.Button type="danger">Click</MyUI.Button><MyUI.Button type="info">Click</MyUI.Button><MyUI.Button type="primary">Click</MyUI.Button><MyUI.Button type="warning">Click</MyUI.Button></>)}
}
ReactDOM.render(<App />,document.getElementById('app')
)

在這里插入圖片描述

class LoginBtnGroup extends React.Component {render() {return (<div><h1>請先登錄</h1></div>)}
}
class WelcomeInfo extends React.Component {render() {return (<div><h1>HI {this.props.username}</h1></div>)}
}
class Header extends React.Component {static componets = {'login': LoginBtnGroup,'welcome': WelcomeInfo}render() {const HeaderUser = Header.componets[this.props.type]return (<HeaderUser{...this.props} />)}
}

在這里插入圖片描述

JSX的props

JS表達式與語句

  • JSX大括號里可以傳入任何js表達式
  • 但不可以傳入語句如if、for、switch、function,非表達式可以在JSX大括號外面使用(如render里、return外)

在這里插入圖片描述

字符字面量

  • 字符串字面量傳入的props能顯示特殊符號
  • JS表達式方式傳入的props將原封不動的顯示
    在這里插入圖片描述
  • 字符串傳入的意義是字符串本意,傳入了字符串true,不代表Bool真假,隱式轉換為真,但全等===true判斷為假

authorShow ={ true }
JS表達式方式傳入的props,在語義和邏輯上都代表Bool真假
a=“1” // 字符串1
a={1} // 數字1

在這里插入圖片描述

  • 字符串字面量去除首位空格、換行
  • 字符串之間多個空格壓縮為一個,加多個$nbsp;
  • 控制換行:<br/>
  • 要顯示<>,使用字符實體&lt &gt
  • 在JS表達式里{'This is a <TITLE>'}可以渲染出<>
    在這里插入圖片描述

剩余運算符

  • 剩余運算符展開props
  • 如果有不用的屬性,先行解構,再展開余下的屬性const { a,...others } = this.props
    在這里插入圖片描述

返回一組JSX

在這里插入圖片描述

子元素

  • 與運算控制邏輯,0是會渲染的,因此不走&&之后
  • 可以改為或運算
  • 或用length === 0判斷
    在這里插入圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/250834.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/250834.shtml
英文地址,請注明出處:http://en.pswp.cn/news/250834.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

javascript --- 數組實用小技巧

一個數組:[a,b,c,d,e],希望滿足以下2個條件: 1.當索引在第0個位置的時候,數組為[b,c,d,e],在第1個位置的時候,數組為[a,c,d,e] … 2.若索引i 和 索引 j 的值相等,則只執行1次. 效果如下: nums [1,2,3,4] nums [1,1,1,2,2,3,4] 實現如下: let nums [1,1,1,2,2,3,4]; let le…

Http的持久連接和管線化

【要點】 1. 什么是持久連接&#xff1f; 2. 什么是管線化&#xff1f; 【總結】 1.什么是持久連接&#xff1f; (keep alive模式) HTTP1.1規定了默認保持長連接&#xff08;HTTP persistent connection &#xff0c;也有翻譯為持久連接&#xff09;;數據傳輸完成了保持TCP連接…

Hexo 版本

Mac hexo s 啟動Hexo服務報錯如下&#xff1a; Error: The module /usr/local/lib/node_modules/hexo-cli/node_modules/.0.8.0dtrace-provider/build/Release/DTraceProviderBindings.node was compiled against a different Node.js version using NODE_MODULE_VERSION 48. T…

dart --- 簡單的閉包

首先得明白下面2點: 全局變量的特點:常駐內存,污染全局變量局部變量的特點:會被垃圾回收機制回收,不會污染作用域… // 閉包.dart void main(){myClosure(){var a 0; // a是一個局部變量.函數執行完畢后將被清理return (){a;print(a);};}var fn myClosure();fn();fn();fn()…

27 JSX函數子元素的應用與思考

JSX的props.children和props本身有部分一致的特性 props.children可以傳遞任何類型的子元素 // 調用子元素回調 num 次&#xff0c;來重復生成組件 function Repeat(props) {// 返回一組JSXlet items [];for (let i 0; i < props.num; i) {items.push(props.children(i));…

Python學習day12(生成器,列表/生成器推導式)

Python學習day12(生成器&#xff0c;列表/生成器推導式) 生成器 初始生成器 我們知道的迭代器有兩種&#xff1a;一種是調用方法直接返回的&#xff0c;一種是可迭代對象通過執行iter方法得到的&#xff0c;迭代器有的好處是可以節省內存。 如果在某些情況下&#xff0c;我們也…

Cascader 級聯選擇器

當一個數據集合有清晰的層級結構時&#xff0c;可通過級聯選擇器逐級查看并選擇。 基礎用法 有兩種觸發子菜單的方式 只需為 Cascader 的options屬性指定選項數組即可渲染出一個級聯選擇器。 通過expand-trigger可以定義展開子級菜單的觸發方式。 本例還展示了change事件&#…

es6 --- String.prototype.padStart

從實際出發理解. 首先看下面代碼 // js var dt new Date(); console.log(dt);下面想把時間格式化,寫一個dateFormat函數 // js function dateFormat(data){var dt new Date(data);var y dt.getFullYear();var m dt. getMonth() 1;var d dt.getDate();var hh dt.getHo…

1 redux初探、用react開發數值增值案例

含義 Redux是專門用作狀態管理的js庫&#xff0c;不是react插件庫可以用在react、angular、vue等項目中能集中式管理react應用中多個組件共享的狀態 使用 npx create-react-app redux1 cnpm install redux -S關鍵字 storereduceractionsubscribe 案例 1. 創建store、并傳…

Python學習筆記_1_基礎_2:數據運算、bytes數據類型、.pyc文件(什么鬼)

Python學習筆記_1_基礎_2&#xff1a;數據運算、bytes數據類型、.pyc文件&#xff08;什么鬼&#xff09; 一、數據運算 Python數據運算感覺和C&#xff0c;Java沒有太大的差異&#xff0c;百度一大堆&#xff0c;這里就不想寫了。比較有意思的是三元運算&#xff0c;記得C和Ja…

LeetCode 8. String to Integer (atoi)

問題鏈接 LeetCode 8. String to Integer (atoi) 題目解析 字符串轉換成數字。 解題思路 個人認為題目并沒有完全講清楚題意。最初以為需要考慮多種情況&#xff0c;小數啊指數啊什么的&#xff0c;后面發現不是這樣的&#xff0c;這題只要關注字符數字問題以及范圍問題。 1.跳…

javascript --- 實戰中體會jsonp

準備:1.需要node環境,node環境配置 -> 百度搜索 “node環境配置” (網上太多了) node是否安裝成功指令如下: 創建如下頁面結構: html結構如下: // jsonp.html <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8">…

2 中間件的使用、異步action的創建

react-redux是react插件 將所有組件分成兩大類&#xff1a;UI組件和容器組件 安裝npm install react-redux -S UI組件&#xff1a; 只負責UI的呈現&#xff0c;不帶有任何業務邏輯不使用this.state所有數據都由this.props提供不使用任何Redux的API&#xff0c;不需要使用store …

PHP數組函數

整理了一份PHP開發中數組操作大全&#xff0c;包含有數組操作的基本函數、數組的分段和填充、數組與棧、數組與列隊、回調函數、排序、計算、其他的數組函數等。 一、數組操作的基本函數 數組的鍵名和值 array_values($arr); 獲得數組的值array_keys($arr); 獲得數組的鍵名ar…

Android Stadio 相關

這幾天&#xff0c;電腦壞了。重裝系統&#xff0c;慢慢的學到了很多Android stadio 的相關知識。總結一下吧&#xff1a; 1.gradle 編譯工具&#xff1a;在工程的gradle/wrapper/gradle–wrapper.properties 里面設置gradle 的版本。 distributionUrlhttps://services.grad…

1 State Hook

Hook&#xff0c;使用在函數組件中不要在循環&#xff0c;條件或嵌套函數中(if、switch、for)調用 Hook 1. 函數指向相同的引用 更新方式&#xff1a;函數組件中state變化時才重新渲染&#xff08;React使用Object.is比較算法來比較state&#xff09;&#xff1b;而類組件每次…

?第五篇? 隊列

隊列&#xff08;queue&#xff09;是只允許在一端進行插入操作&#xff0c;而在另一端進行刪除操作的線性表。 隊列是一種先進先出的&#xff08;First In First Out&#xff09;的線性表&#xff0c;簡稱FIFO。允許插入的一端為隊尾&#xff0c;允許刪除的一端為隊頭。隊列不…

es6 --- 數組的擴展

經常遇到對數組的操作…下面是《ES6標準入門》(第3版)中對數組擴展的(部分)描述: 擴展運算符(…): console.log(...[1,2,3]) // 1 2 3console.log(1, ... [2,3,4], 5) // 1 2 3 4 5擴展運算符代替數組的apply方法 // ES5 function f(x,y,z) {// ... } var args [1,2,3]; f.a…

算法 - 排序穩定性總結

排序方式 時間復雜度 空間復雜度 穩定性 平均情況 最壞情況 最好情況 插入排序 O(n^2) O(n^2) O(n) O(1) 穩定 希爾排序 O(n^1.3) O(1) 不穩定 冒泡排序 O(n^2) O(n^2) O(n) O(1) 穩定 快速排序 O(nlogn) O(n^2) O(nlogn) O(logn) 不穩定 選擇排…

node --- 實踐中理解跨域

經常可以見到.說解決跨域只要返回加上"Access-Control-Allow-Origin"頭部就行… 下面從實踐中一步一步的理解. 1.環境準備: 1. node.js (http://nodejs.cn/) 自行下載配置, 完畢后(cmd)輸入 node --version 若顯示版本號則代表成功// ps: node(中的npm)方便下載資源…