react組件首字母一定要大寫嗎

這篇文章主要介紹了react組件首字母一定要大寫嗎的相關(guān)知識(shí),內(nèi)容詳細(xì)易懂,操作簡(jiǎn)單快捷,具有一定借鑒價(jià)值,相信大家閱讀完這篇react組件首字母一定要大寫嗎文章都會(huì)有所收獲,下面我們一起來(lái)看看吧。

在頭屯河等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場(chǎng)前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供網(wǎng)站制作、成都網(wǎng)站制作 網(wǎng)站設(shè)計(jì)制作定制制作,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),成都品牌網(wǎng)站建設(shè),成都營(yíng)銷網(wǎng)站建設(shè),外貿(mào)營(yíng)銷網(wǎng)站建設(shè),頭屯河網(wǎng)站建設(shè)費(fèi)用合理。

react組件首字母必須大寫;因?yàn)镽eact根據(jù)首字母是否大寫來(lái)區(qū)分是react組件還是dom元素。React中使用JSX語(yǔ)法,但瀏覽器無(wú)法識(shí)別JSX語(yǔ)法,需通過(guò)babel對(duì)JSX語(yǔ)法進(jìn)行轉(zhuǎn)義;而如果組件的首字母為小寫時(shí),其會(huì)被認(rèn)定為原生DOM標(biāo)簽,創(chuàng)建一個(gè)不存在的標(biāo)簽是會(huì)報(bào)錯(cuò)的。

react組件首字母一定要大寫嗎

本教程操作環(huán)境:Windows7系統(tǒng)、react18版、Dell G3電腦。

在React中聲明組件時(shí)組件名的第一個(gè)字母必須是大寫嗎?為什么?

必須,React根據(jù)首字母是否大寫來(lái)區(qū)分是react組件還是dom元素。

之前在寫react遇到過(guò)這樣的報(bào)錯(cuò)

Warning: The tag  is unrecognized in this browser. If you meant to render a React component, start its name with an uppercase letter.
in app (at src/index.tsx:6)

這是因?yàn)閞eact組件沒(méi)有大寫導(dǎo)致的。

React中使用JSX語(yǔ)法,但瀏覽器無(wú)法識(shí)別JSX語(yǔ)法,需通過(guò)babel對(duì)JSX語(yǔ)法進(jìn)行轉(zhuǎn)義;而如果組件的首字母為小寫時(shí),其會(huì)被認(rèn)定為原生DOM標(biāo)簽,創(chuàng)建一個(gè)不存在的標(biāo)簽是會(huì)報(bào)錯(cuò)的。

原理:JSX語(yǔ)法 向 真實(shí)DOM的轉(zhuǎn)換

我們?cè)?React 中都是寫的 JSX語(yǔ)法,從 JSX語(yǔ)法 到頁(yè)面上的 真實(shí)DOM大概需要經(jīng)歷以下幾個(gè)階段:JSX語(yǔ)法 —> 虛擬DOM(JS對(duì)象) —> 真實(shí)DOM。

因?yàn)闉g覽器是無(wú)法識(shí)別JSX語(yǔ)法的,因此我們需要通過(guò) babel 對(duì)JSX語(yǔ)法進(jìn)行轉(zhuǎn)義,然后才能生成虛擬DOM對(duì)象,而原因就是在這里。我們可以看一下babel是如何轉(zhuǎn)義JSX語(yǔ)法的:

react組件首字母一定要大寫嗎

react組件首字母一定要大寫嗎

babel在進(jìn)行轉(zhuǎn)義JSX語(yǔ)法時(shí),是調(diào)用了 React.createElement() 這個(gè)方法,這個(gè)方法需要接收三個(gè)參數(shù):type, config, children。第一個(gè)參數(shù)聲明了這個(gè)元素的類型。

對(duì)比上面兩張圖,圖一中,我在創(chuàng)建自定義組件時(shí)沒(méi)有首字母大寫。 而 babel 在轉(zhuǎn)義時(shí)把它當(dāng)成了一個(gè)字符串 傳遞進(jìn)去了;圖二中,我把首字母大寫了,babel 在轉(zhuǎn)義時(shí)傳遞了一個(gè)變量進(jìn)去。

問(wèn)題就在這里,如果傳遞的是一個(gè)字符串,那么在創(chuàng)建虛擬DOM對(duì)象時(shí),React會(huì)認(rèn)為這是一個(gè)簡(jiǎn)單的HTML標(biāo)簽,但是這顯然不是一個(gè)簡(jiǎn)單的HTML標(biāo)簽,因此去創(chuàng)建一個(gè)不存在的標(biāo)簽肯定是會(huì)報(bào)錯(cuò)的。

如果首字母大寫,那么就會(huì)當(dāng)成一個(gè)變量傳遞進(jìn)去,這個(gè)時(shí)候React會(huì)知道這是一個(gè)自定義組件,因此他就不會(huì)報(bào)錯(cuò)了。

所以:

同理,上述錯(cuò)誤的寫法因?yàn)槭切懀詁abel就把clock當(dāng)作是標(biāo)簽生成了,而html中又沒(méi)有這個(gè)元素,所以導(dǎo)致以一種比較奇怪的方式存在

react組件首字母一定要大寫嗎

關(guān)于“react組件首字母一定要大寫嗎”這篇文章的內(nèi)容就介紹到這里,感謝各位的閱讀!相信大家對(duì)“react組件首字母一定要大寫嗎”知識(shí)都有一定的了解,大家如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道。

本文題目:react組件首字母一定要大寫嗎
網(wǎng)頁(yè)地址:http://muchs.cn/article30/isgeso.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站收錄、移動(dòng)網(wǎng)站建設(shè)、網(wǎng)頁(yè)設(shè)計(jì)公司、虛擬主機(jī)、網(wǎng)站策劃、小程序開發(fā)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站