成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

在React條件渲染中使用三元表達式和“&&”

開發 前端
React 組件可以通過多種方式決定渲染內容。你可以使用傳統的 if 語句或 switch 語句。在本文中,我們將探討一些替代方案。但要注意,如果你不小心,有些方案會帶來自己的陷阱。

[[245395]]

React 組件可以通過多種方式決定渲染內容。你可以使用傳統的 if 語句或 switch 語句。在本文中,我們將探討一些替代方案。但要注意,如果你不小心,有些方案會帶來自己的陷阱。

三元表達式 vs if/else

假設我們有一個組件被傳進來一個 name 屬性。 如果這個字符串非空,我們會顯示一個問候語。否則,我們會告訴用戶他們需要登錄。

這是一個只實現了如上功能的無狀態函數式組件(SFC)。

  1. const MyComponent = ({ name }) => {
  2. if (name) {
  3. return (
  4. <div className="hello">
  5. Hello {name}
  6. </div>
  7. );
  8. }
  9. return (
  10. <div className="hello">
  11. Please sign in
  12. </div>
  13. );
  14. };

這個很簡單但是我們可以做得更好。這是使用三元運算符conditional ternary operator編寫的相同組件。

  1. const MyComponent = ({ name }) => (
  2. <div className="hello">
  3. {name ? `Hello ${name}` : 'Please sign in'}
  4. </div>
  5. );

請注意這段代碼與上面的例子相比是多么簡潔。

有幾點需要注意。因為我們使用了箭頭函數的單語句形式,所以隱含了return 語句。另外,使用三元運算符允許我們省略掉重復的 <div className="hello"> 標記。

三元表達式 vs &&

正如您所看到的,三元表達式用于表達 if/else 條件式非常好。但是對于簡單的 if 條件式怎么樣呢?

讓我們看另一個例子。如果 isPro(一個布爾值)為真,我們將顯示一個獎杯表情符號。我們也要渲染星星的數量(如果不是 0)。我們可以這樣寫。

  1. const MyComponent = ({ name, isPro, stars}) => (
  2. <div className="hello">
  3. <div>
  4. Hello {name}
  5. {isPro ? '♨' : null}
  6. </div>
  7. {stars ? (
  8. <div>
  9. Stars:{'☆'.repeat(stars)}
  10. </div>
  11. ) : null}
  12. </div>
  13. );

請注意 else 條件返回 null 。 這是因為三元表達式要有“否則”條件。

對于簡單的 if 條件式,我們可以使用更合適的東西:&& 運算符。這是使用 && 編寫的相同代碼。

  1. const MyComponent = ({ name, isPro, stars}) => (
  2. <div className="hello">
  3. <div>
  4. Hello {name}
  5. {isPro && '♨'}
  6. </div>
  7. {stars && (
  8. <div>
  9. Stars:{'☆'.repeat(stars)}
  10. </div>
  11. )}
  12. </div>
  13. );

沒有太多區別,但是注意我們消除了每個三元表達式***面的 : null (else 條件式)。一切都應該像以前一樣渲染。

嘿!約翰得到了什么?當什么都不應該渲染時,只有一個 0。這就是我上面提到的陷阱。這里有解釋為什么:

根據 MDN,一個邏輯運算符“和”(也就是 &&):

expr1 && expr2

如果 expr1 可以被轉換成 false ,返回 expr1;否則返回 expr2。 如此,當與布爾值一起使用時,如果兩個操作數都是 true&& 返回 true ;否則,返回 false

好的,在你開始拔頭發之前,讓我為你解釋它。

在我們這個例子里, expr1 是變量 stars,它的值是 0,因為 0 是假值,0 會被返回和渲染。看,這還不算太壞。

我會簡單地這么寫。

如果 expr1 是假值,返回 expr1 ,否則返回 expr2

所以,當對非布爾值使用 && 時,我們必須讓這個假值返回 React 無法渲染的東西,比如說,false 這個值。

我們可以通過幾種方式實現這一目標。讓我們試試吧。

  1. {!!stars && (
  2. <div>
  3. {'☆'.repeat(stars)}
  4. </div>
  5. )}

注意 stars 前的雙感嘆操作符(!!)(呃,其實沒有雙感嘆操作符。我們只是用了感嘆操作符兩次)。

***個感嘆操作符會強迫 stars 的值變成布爾值并且進行一次“非”操作。如果 stars0 ,那么 !stars 會是 true

然后我們執行第二個操作,所以如果 stars0!!stars 會是 false。正好是我們想要的。

如果你不喜歡 !!,那么你也可以強制轉換出一個布爾數比如這樣(這種方式我覺得有點冗長)。

  1. {Boolean(stars) && (

或者只是用比較符產生一個布爾值(有些人會說這樣甚至更加語義化)。

  1. {stars > 0 && (

關于字符串

空字符串與數字有一樣的毛病。但是因為渲染后的空字符串是不可見的,所以這不是那種你很可能會去處理的難題,甚至可能不會注意到它。然而,如果你是***主義者并且不希望 DOM 上有空字符串,你應采取我們上面對數字采取的預防措施。

其它解決方案

一種可能的將來可擴展到其他變量的解決方案,是創建一個單獨的 shouldRenderStars 變量。然后你用 && 處理布爾值。

  1. const shouldRenderStars = stars > 0;
  1. return (
  2. <div>
  3. {shouldRenderStars && (
  4. <div>
  5. {'☆'.repeat(stars)}
  6. </div>
  7. )}
  8. </div>
  9. );

之后,在將來,如果業務規則要求你還需要已登錄,擁有一條狗以及喝淡啤酒,你可以改變 shouldRenderStars 的得出方式,而返回的內容保持不變。你還可以把這個邏輯放在其它可測試的地方,并且保持渲染明晰。

  1. const shouldRenderStars =
  2. stars > 0 && loggedIn && pet === 'dog' && beerPref === 'light`;
  1. return (
  2. <div>
  3. {shouldRenderStars && (
  4. <div>
  5. {'☆'.repeat(stars)}
  6. </div>
  7. )}
  8. </div>
  9. );

結論

我認為你應該充分利用這種語言。對于 JavaScript,這意味著為 if/else 條件式使用三元表達式,以及為 if 條件式使用 && 操作符。

我們可以回到每處都使用三元運算符的舒適區,但你現在消化了這些知識和力量,可以繼續前進 && 取得成功了。 

責任編輯:龐桂玉 來源: Linux中國
相關推薦

2020-10-14 10:18:05

Python三元表達式代碼

2023-09-06 09:40:29

2023-05-24 16:41:41

React前端

2022-01-16 07:48:33

腳本Bash 工具

2023-11-30 08:30:12

Python三元表達

2023-09-07 08:05:32

三元表達式自動

2023-10-07 08:25:09

Java處理工具正則表達式

2011-04-22 11:07:24

groovyJava

2009-03-16 14:01:24

正則表達式函數SQL

2009-07-03 17:52:17

JSP2.0

2023-04-17 19:53:37

編程正則表達式

2024-12-25 15:09:38

Python字符串函數

2024-01-05 17:41:36

Rust編程循環

2010-03-25 18:25:36

Python正則表達式

2009-04-23 11:24:44

SQL正則表達式查詢

2012-05-08 13:29:01

VB

2024-10-09 16:35:20

Python正則表達式

2018-09-27 15:25:08

正則表達式前端

2014-01-05 17:41:09

PostgreSQL表達式

2009-09-16 18:03:05

Java正則表達式正則表達式實現
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 成年人在线观看 | 精品久久伊人 | 日韩人体在线 | 午夜欧美一区二区三区在线播放 | 久久精品亚洲精品国产欧美 | 一级做a爰片性色毛片 | 日韩视频在线观看中文字幕 | 在线国产一区二区三区 | 亚洲一区二区三区在线免费观看 | 久久久久久久国产精品影院 | 亚洲+变态+欧美+另类+精品 | 欧美日韩国产精品一区二区 | 中文字幕欧美一区 | av大片在线观看 | 黄色大片视频 | 久久久久久久综合色一本 | 亚洲一区二区在线播放 | 中文字幕在线观看成人 | 国产精品精品视频一区二区三区 | 最新国产精品视频 | 亚洲一区二区三区高清 | 成人特级毛片 | 久久久久久久亚洲精品 | 精品国产一区久久 | 久久国产精品视频 | 午夜成人免费视频 | 亚洲国产精品美女 | 国产成人综合一区二区三区 | 国产在线一区二 | 欧美国产精品一区二区三区 | 欧美一区二区激情三区 | 国产精品国产三级国产a | 亚洲精品一二三区 | 91社影院在线观看 | 国产精品国产a | 黄色一级大片视频 | www.毛片| 精产国产伦理一二三区 | 欧美精品免费观看二区 | 视频一区在线观看 | 亚洲一区二区三区高清 |