91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

react中組件名稱必須大寫的原因

發布時間:2020-11-26 09:51:14 來源:億速云 閱讀:557 作者:栢白 欄目:web開發

這篇文章主要介紹了react中組件名稱必須大寫的原因,具有一定借鑒價值,需要的朋友可以參考下。下面就和我一起來看看吧。

react中組件名稱的首字母必須要用大寫。原因:React中使用JSX語法,但瀏覽器無法識別JSX語法,需通過babel對JSX語法進行轉義;而如果組件的首字母為小寫時,其會被認定為原生DOM標簽,創建一個不存在的標簽是會報錯的。

react中組件名稱必須大寫的原因

react組件名稱的首字母一定要用大寫

錯誤的寫法: 組件首字母沒有大寫

function clock(props){  
 return (
    <p>
      <h2>現在的時間是{props.date.toDateString()}</h2>
    </p>
 ) }
錯誤的寫法會導致頁面無法顯示內容且報錯,但又可以通過f12查看到標簽以一種比較奇怪的方式存在,

react中組件名稱必須大寫的原因

正確的寫法:

function Clock(props){  
 return (
    <p>
      <h2>現在的時間是{props.date.toDateString()}</h2>
    </p>
 ) }

那究竟是為什么呢?

JSX語法 向 真實DOM的轉換

我們在 React 中都是寫的 JSX語法,從 JSX語法 到頁面上的 真實DOM大概需要經歷以下幾個階段JSX語法 —> 虛擬DOM(JS對象) —> 真實DOM。

因為瀏覽器是無法識別JSX語法的,因此我們需要通過 babel 對JSX語法進行轉義,然后才能生成虛擬DOM對象,而原因就是在這里。我們可以看一下babel是如何轉義JSX語法的:

react中組件名稱必須大寫的原因
react中組件名稱必須大寫的原因


babel在進行轉義JSX語法時,是調用了 React.createElement() 這個方法,這個方法需要接收三個參數:type, config, children。第一個參數聲明了這個元素的類型

對比上面兩張圖,圖一中,我在創建自定義組件時沒有首字母大寫。 而 babel 在轉義時把它當成了一個字符串 傳遞進去了;圖二中,我把首字母大寫了,babel 在轉義時傳遞了一個變量進去。

問題就在這里,如果傳遞的是一個字符串,那么在創建虛擬DOM對象時,React會認為這是一個簡單的HTML標簽,但是這顯然不是一個簡單的HTML標簽,因此去創建一個不存在的標簽肯定是會報錯的。

如果首字母大寫,那么就會當成一個變量傳遞進去,這個時候React會知道這是一個自定義組件,因此他就不會報錯了。

所以:

同理,上述錯誤的寫法因為是小寫,所以babel就把clock當作是標簽生成了,而html中又沒有這個元素,所以導致以一種比較奇怪的方式存在

react中組件名稱必須大寫的原因


以上就是react中組件名稱必須大寫的原因的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎來億速云行業資訊!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

岚皋县| 鹤山市| 综艺| 金川县| 镇坪县| 浠水县| 隆回县| 辛集市| 青神县| 南丰县| 明光市| 留坝县| 南川市| 绵阳市| 兰西县| 浏阳市| 瓮安县| 靖安县| 于都县| 灵台县| 石城县| 静安区| 昌乐县| 乌兰浩特市| 高安市| 清流县| 赤水市| 丽江市| 礼泉县| 东方市| 嫩江县| 彭泽县| 蛟河市| 陇西县| 恩平市| 曲阜市| 凤台县| 稷山县| 冕宁县| 安宁市| 黎城县|