中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

新手React開發(fā)人員容易做錯的事有哪些

這篇文章主要講解了“新手React開發(fā)人員容易做錯的事有哪些”,文中的講解內(nèi)容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“新手React開發(fā)人員容易做錯的事有哪些”吧!

志丹ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為成都創(chuàng)新互聯(lián)公司的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:13518219792(備注:SSL證書合作)期待與您的合作!

1. 忘記大寫React組件

考慮一下這段代碼,它創(chuàng)建一個簡單的div,其中包含父組件的標題。里面有一個子組件,其中包含帶有一些文本的div。

class childComponent extends React.Component {   render() {     return (       <div className='childDiv'>         <p>Child Component</p>       </div>     );   } }  class ParentComponent extends React.Component {   render() {     return (       <div className='parentDiv'>         <h2 className='parentHeader'>Parent Component</h2>         <childComponent />       </div>     );   } }  export default ParentComponent;

您認為代碼運行時會出現(xiàn)什么?

新手React開發(fā)人員容易做錯的事有哪些

childComponent 未渲染。它去哪兒了?代碼編譯成功,終端也沒有錯誤。

再次查看子組件的代碼。注意組件的名稱,你注意到什么不同了嗎?

在瀏覽器中打開控制臺,瀏覽器控制臺警告的大小寫不正確

新手React開發(fā)人員容易做錯的事有哪些

事實證明,React將小寫組件視為DOM標記。如果你是React的新手,你可能已經(jīng)錯過了React文檔中的這個小細節(jié)。

如果不了解這一點,初學者常常會陷入這樣的困惑:即他們的代碼編譯沒有任何錯誤,到底哪里出了問題?

解決方法很簡單,大寫您的組件。

2. 錯誤地調(diào)用收到的props

要訪問由父組件傳入的prop,子組件必須確保它們調(diào)用了正確的prop名稱。

還可以使用另一個變量名將Props傳遞給子組件??紤]以下代碼片段:

class ChildComponent extends React.Component {   render() {     const { randomString } = this.props;      return (       <div className='childDiv'>         <p>{randomString}</p>       </div>     );   } }  class ParentComponent extends React.Component {   render() {     const randomString = 'lorem ipsum';          return (       <div className='parentDiv'>         <h2 className='parentHeader'>Parent Component</h2>         <ChildComponent mainText={randomString} />       </div>     );   } }

盡管此代碼可以編譯并運行無誤,但 ChildComponent內(nèi)不會渲染任何文本。

<ChildComponent mainText={randomString} />

仔細看看這一行代碼,在 ParentComponent 中聲明的變量 randomString 作為名為 mainText 的prop傳遞給  ChildComponent。

然而,ChildComponent 試圖從它收到的prop中訪問 randomString。由于它僅接收 mainText  作為prop,因此將導致未定義的值分配給在 ChildComponent 中聲明的 randomString。結(jié)果,其

標記內(nèi)未呈現(xiàn)任何內(nèi)容。

注意哪些prop被傳遞到您的組件中,并相應地訪問它們。這將在調(diào)試期間為您節(jié)省一些不必要的麻煩。

3. 傳遞不正確的Props類型

如果所接收的prop不是預期的類型,那么依賴于這些接收prop的組件可能會有不同的行為。

class ChildComponent extends React.Component {   render() {     const { showIntro, showBody } = this.props;      return (       <div className='childDiv'>         {showIntro && <p>Hello!</p>}         {showBody && <p>Spot the mistake!</p>}       </div>     );   } }

考慮這個有兩個prop的 ChildComponent:showIntro 和 showBody。它顯示“你好!和“發(fā)現(xiàn)錯誤!”只有當showIntro  和 showBody 分別設置為 true 時才會這樣。

ChildComponent 希望將兩個布爾值作為prop傳遞。如果在父組件中執(zhí)行類似的操作,會發(fā)生什么情況?

<ChildComponent showIntro='false' showBody='false' /> <ChildComponent showIntro={'false'} showBody={'false'} /> <ChildComponent showIntro={false} showBody={false} />

在prop中使用了不同的引號和大括號。但是,它們的行為將不同??纯催@個:

新手React開發(fā)人員容易做錯的事有哪些

前兩個 ChildComponent 都渲染了兩個<p>標記,而最后一個 ChildComponent 沒有渲染。

作為prop傳遞的 'false' 和 {'false'} 會導致無意中為 showIntro 和 showBody 分配了一個值為 false  的字符串,而不是布爾值 false。

對于前兩個 ChildComponent,將 showIntro 和 showBody 都計算為 true。

這是由于 && 運算符的隱式強制類型轉(zhuǎn)換。當 && 運算符檢查 showIntro 或  showBody(均為字符串)時,兩個字符串都將強制為 true。

最后一個 ChildComponent 接收到布爾值 false,因此它沒有正確渲染任何內(nèi)容。

console.log(`showIntro type: ${typeof showIntro}`); console.log(`showIntro evaluated to: ${showIntro && true}`); console.log(`showBody type: ${typeof showBody}`); console.log(`showBody evaluated to: ${showBody && true}`);

為了確認這一點,我們運行 console.log() 來檢查每個 ChildComponent 中prop的運行結(jié)果。

新手React開發(fā)人員容易做錯的事有哪些

正如這里所演示的,初學者在將prop傳遞給其他組件時能夠區(qū)分使用引號和花括號之間的區(qū)別是非常重要的。

您可以使用引號來傳遞字符串文字。

<MyComponent data='Hello World!'/> // passing in a String

花括號用于傳遞JavaScript表達式。

<MyComponent data={2468} /> // passing in a Number <MyComponent data={true} /> // passing in a Boolean

以下是Reac文檔中的一些注意事項:

將JavaScript表達式嵌入屬性中時,請勿在大括號周圍加上引號。您應該使用引號(用于字符串值)或大括號(用于表達式),但不要在同一屬性中都使用引號。

4. 在render()內(nèi)部調(diào)用setState()

下圖無限循環(huán)錯誤消息

新手React開發(fā)人員容易做錯的事有哪些

盡管您的組件中沒有 componentWillUpdate() 或 componentWillUpdate(),您仍可能遇到此錯誤。當您在  render() 函數(shù)中調(diào)用 setState() 時也會發(fā)生此錯誤。

為什么會這樣?每次調(diào)用 setState() 時,React將通過調(diào)用 render() 重新渲染。您的 render()  函數(shù)內(nèi)部是什么?setState()。你看到結(jié)果了嗎?一個無限循環(huán)。

只需將 setState() 調(diào)用移到 render() 函數(shù)之外即可。

如果在組件掛載后必須初始化狀態(tài)(也許是從API端點提取數(shù)據(jù)),請在 componentDidMoun() 中進行。

如果可以在組件掛載之前初始化狀態(tài),也可以使用構(gòu)造函數(shù)來完成。

5. setState()的異步性

在調(diào)試時,通常使用 console.log() 打印值。但是,當代碼異步運行時,這不能很好地工作。

handleCounterIncrement = () => {   const { counter } = this.state;   console.log(`Before update: ${counter}`);   this.setState({ counter: counter + 1 });   console.log(`After update: ${counter}`); };

你以前試過這樣做嗎?壞消息&mdash;&mdash;setState() 調(diào)用是異步的。不能保證給定的代碼將按順序執(zhí)行。它可能導致如下輸出:

新手React開發(fā)人員容易做錯的事有哪些

在執(zhí)行 setState() 之前執(zhí)行了兩個 console.log() 調(diào)用。因此,它兩次打印前一個狀態(tài)的值。

如果希望在調(diào)用 setState() 之前和之后檢查狀態(tài)的值,請在 setState() 中將回調(diào)作為第二個參數(shù)傳遞。

handleCounterIncrement = () => {   const { counter } = this.state;   console.log(`before update: ${counter}`);   this.setState({ counter: counter + 1 }, () => {     console.log(`after update: ${this.state.counter}`);   }); };

回調(diào)將在 setState() 完成后執(zhí)行,從而為 console.log() 提供同步行為。

新手React開發(fā)人員容易做錯的事有哪些

感謝各位的閱讀,以上就是“新手React開發(fā)人員容易做錯的事有哪些”的內(nèi)容了,經(jīng)過本文的學習后,相信大家對新手React開發(fā)人員容易做錯的事有哪些這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關知識點的文章,歡迎關注!

新聞名稱:新手React開發(fā)人員容易做錯的事有哪些
鏈接地址:http://m.rwnh.cn/article42/jepghc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供服務器托管虛擬主機、品牌網(wǎng)站建設、移動網(wǎng)站建設面包屑導航、商城網(wǎng)站

廣告

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

搜索引擎優(yōu)化
齐齐哈尔市| 晴隆县| 封开县| 平定县| 昭平县| 水城县| 泸水县| 松潘县| 额济纳旗| 平度市| 简阳市| 玉林市| 南昌市| 宁安市| 高雄市| 武鸣县| 靖西县| 桑植县| 蕲春县| 泸定县| 商城县| 车险| 驻马店市| 财经| 东山县| 通辽市| 扎兰屯市| 竹山县| 堆龙德庆县| 合山市| 新宁县| 多伦县| 宝坻区| 从化市| 新田县| 扎赉特旗| 贵溪市| 盐山县| 修武县| 含山县| 巢湖市|