這篇文章主要介紹了react中組件名稱必須大寫的原因,具有一定借鑒價值,需要的朋友可以參考下。下面就和我一起來看看吧。
成都創(chuàng)新互聯(lián)公司成立于2013年,我們提供高端網站建設公司、成都網站制作、網站設計、網站定制、營銷型網站建設、微信小程序開發(fā)、微信公眾號開發(fā)、成都網站營銷服務,提供專業(yè)營銷思路、內容策劃、視覺設計、程序開發(fā)來完成項目落地,為輕質隔墻板企業(yè)提供源源不斷的流量和訂單咨詢。react中組件名稱的首字母必須要用大寫。原因:React中使用JSX語法,但瀏覽器無法識別JSX語法,需通過babel對JSX語法進行轉義;而如果組件的首字母為小寫時,其會被認定為原生DOM標簽,創(chuàng)建一個不存在的標簽是會報錯的。
react組件名稱的首字母一定要用大寫
錯誤的寫法: 組件首字母沒有大寫
function clock(props){ return (
現在的時間是{props.date.toDateString()}
) }
正確的寫法:
function Clock(props){ return (
現在的時間是{props.date.toDateString()}
) }
那究竟是為什么呢?
JSX語法 向 真實DOM的轉換
我們在 React 中都是寫的 JSX語法,從 JSX語法 到頁面上的 真實DOM大概需要經歷以下幾個階段:JSX語法 —> 虛擬DOM(JS對象) —> 真實DOM。
因為瀏覽器是無法識別JSX語法的,因此我們需要通過babel 對JSX語法進行轉義
,然后才能生成虛擬DOM對象,而原因就是在這里。我們可以看一下babel是如何轉義JSX語法的:
babel在進行轉義JSX語法時,是調用了 React.createElement() 這個方法
,這個方法需要接收三個參數:type, config, children
。第一個參數聲明了這個元素的類型。
對比上面兩張圖,圖一中,我在創(chuàng)建自定義組件時沒有首字母大寫
。 而 babel 在轉義時把它當成了一個字符串 傳遞進去了;圖二中,我把首字母大寫了
,babel 在轉義時傳遞了一個變量進去。
問題就在這里,如果傳遞的是一個字符串,那么在創(chuàng)建虛擬DOM對象時,React會認為這是一個簡單的HTML標簽,但是這顯然不是一個簡單的HTML標簽,因此去創(chuàng)建一個不存在的標簽肯定是會報錯的。
如果首字母大寫,那么就會當成一個變量傳遞進去,這個時候React會知道這是一個自定義組件,因此他就不會報錯了。
所以:
同理,上述錯誤的寫法因為是小寫,所以babel就把clock當作是標簽生成了,而html中又沒有這個元素,所以導致以一種比較奇怪的方式存在
以上就是react中組件名稱必須大寫的原因的詳細內容了,看完之后是否有所收獲呢?如果想了解更多相關內容,歡迎來創(chuàng)新互聯(lián)網站建設公司,行業(yè)資訊!