react寫代碼需要注意的坑

1.purecomponent 前后進(jìn)行淺比較

class A extends React.purecomponet{

}底靠,

2.能直接對(duì)state直接進(jìn)行賦值 操作鳖眼,尤其使用purecomponent時(shí)會(huì)認(rèn)為賦值后的state與舊state是一個(gè)狀態(tài)從而不進(jìn)行渲染

3.不用index值key的值?

當(dāng)使用map,forEach遍歷數(shù)組時(shí)祭衩,因?yàn)樾枰胟ey來表示元素的唯一灶体。如果key = index,遍歷完的新數(shù)組的一個(gè)元素進(jìn)行刪除時(shí)掐暮,因?yàn)閕ndex是從0開始產(chǎn)生蝎抽,刪掉元素的index會(huì)繼承給下一個(gè),這是下一個(gè)僅僅是index改變了但是數(shù)據(jù)內(nèi)容沒有變路克,但是新虛擬dom進(jìn)行舊虛擬dom數(shù)進(jìn)行對(duì)比發(fā)現(xiàn)前后這index=2的這元素的內(nèi)容不一樣的就好重新進(jìn)行一遍不必要的渲染

eg:插一個(gè)圖片例子 如圖刪除l3樟结,l4的index就變成

2了,虛擬dom對(duì)key進(jìn)行比較發(fā)現(xiàn)前后index=2的內(nèi)容改變了就渲染這部分精算,但實(shí)際上我們不希望它渲染因?yàn)閘4內(nèi)容沒有變

發(fā)現(xiàn)一個(gè)新的教程講的很詳細(xì)https://www.cnblogs.com/wonyun/p/6743988.html

3.獲取input值的方法

獲取input值的方法有兩種推薦ref瓢宦,因?yàn)槟苌賹?duì)dom操作就少對(duì)他操作

方法一:利用React的ref訪問DOM元素取值并提交 ?灰羽?刁笙?

方法二:利用DOM提供的Event對(duì)象的target事件屬性取值并提交

這個(gè)博主寫的詳解https://blog.csdn.net/hsany330/article/details/92764178

4.復(fù)制一個(gè)數(shù)組的問題 ? ? ? ?

復(fù)制于->侵刪 ?https://www.cnblogs.com/jkr666666/p/7930228.html

var a1 = [1,2,3]; ?

var a2 = a1;

a2[0] = 90;

console.log(a1[0]) //90

解析:數(shù)組是復(fù)合的數(shù)據(jù)類型,直接復(fù)制的話谦趣,只是復(fù)制了指向底層數(shù)據(jù)結(jié)構(gòu)的指針疲吸,而不能克隆一個(gè)全新的數(shù)據(jù);

上面的代碼中前鹅,a2并不是a1的克隆摘悴,而是指向同一分?jǐn)?shù)據(jù)的另一個(gè)指針。修改a2,會(huì)直接導(dǎo)致a1的變化舰绘。

es5 可以同過下面的方法來克隆一個(gè)新的數(shù)組:

方法1:

var a1 = [1, 2, 3];

var a2 = a1.concat();

a2[0] = 90;

console.log(a1[0]) //1

方法2:

var a1 = [1, 2, 3];

var a2 = JSON.parse(JSON.stringify(a1));

a2[0] = 90;

console.log(a1[0]) //1


es6克隆一個(gè)新的數(shù)組的方法:

const a1 = [1,2,3];

寫法一:

const a2 = [...a1]; //當(dāng)添加的是對(duì)象時(shí)可以把[]換成{}

寫法2 :

const [...a2] = a1;

5.點(diǎn)擊事件傳參問題?

eg:點(diǎn)擊delete時(shí)刪除當(dāng)前l(fā)i蹂喻,遇到的問題是怎么li的index傳給button,想到了

綁定函數(shù)bind()捂寿,前提用了map渲染數(shù)據(jù)產(chǎn)生li

<ul>

? ? <li key={index}>

? ? ? ? <button onClick={this.deleteItem.bind(this, index)}>delete</button>

? ? <li>

<ul/>



deleteItem(index: number, e) {

? ? // console.log(a, e.target);

? ? this.props.deleteItem(index);

? }

然后想問bind()到底有幾個(gè)參數(shù) 口四,看到了如下文章https://blog.csdn.net/genius_yym/article/details/54135567

this.handleclick.bind(this,要傳的參數(shù))? handleclick(傳過來的參數(shù)秦陋,event) ?

事件–this.handleclick.bind(this蔓彩,要傳的參數(shù))

函數(shù)–handleclick(傳過來的參數(shù),event)/ handleclick(傳過來的參數(shù))

版權(quán)聲明:本5小結(jié)為CSDN博主「mcya」的原創(chuàng)文章,遵循 CC 4.0 BY-SA 版權(quán)協(xié)議赤嚼,轉(zhuǎn)載請(qǐng)附上原文出處鏈接及本聲明旷赖。

6.受控組件與非受控組件

http://www.reibang.com/p/d2ca25587688

7.react usecallback

https://zhuanlan.zhihu.com/p/56975681

http://www.reibang.com/p/585554f77ecf

8.react hooks

http://www.reibang.com/p/6c43b440dab8

9.useState hooks?

setX(e=>e+1),設(shè)置函數(shù)參數(shù)可以是一個(gè)函數(shù)可以

https://www.cnblogs.com/fundebug/archive/2019/08/22/4-react-usestate-hook-examples.html

10.深拷貝與淺拷貝 前端數(shù)據(jù)結(jié)構(gòu)

http://www.reibang.com/p/5e0e8d183102

11 react 實(shí)現(xiàn)tree

12.函數(shù)組件渲染

https://blog.csdn.net/CVSvsvsvsvs/article/details/93421092

13.Functions are not valid as a React child. This may happen if you return a Component instead of <Component /> from render. Or maybe you meant to call this function rather than return it.

? ? in di

https://www.hellojava.com/a/54273.html

14.React中綁定this并傳參的三種方式

https://blog.csdn.net/qq_43512502/article/details/90965996

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市更卒,隨后出現(xiàn)的幾起案子等孵,更是在濱河造成了極大的恐慌,老刑警劉巖蹂空,帶你破解...
    沈念sama閱讀 222,378評(píng)論 6 516
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件俯萌,死亡現(xiàn)場離奇詭異,居然都是意外死亡上枕,警方通過查閱死者的電腦和手機(jī)咐熙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,970評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來姿骏,“玉大人糖声,你說我怎么就攤上這事斤彼》质荩” “怎么了?”我有些...
    開封第一講書人閱讀 168,983評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵琉苇,是天一觀的道長嘲玫。 經(jīng)常有香客問我,道長并扇,這世上最難降的妖魔是什么去团? 我笑而不...
    開封第一講書人閱讀 59,938評(píng)論 1 299
  • 正文 為了忘掉前任,我火速辦了婚禮穷蛹,結(jié)果婚禮上土陪,老公的妹妹穿的比我還像新娘。我一直安慰自己肴熏,他們只是感情好鬼雀,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,955評(píng)論 6 398
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蛙吏,像睡著了一般源哩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上鸦做,一...
    開封第一講書人閱讀 52,549評(píng)論 1 312
  • 那天励烦,我揣著相機(jī)與錄音,去河邊找鬼泼诱。 笑死坛掠,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播却音,決...
    沈念sama閱讀 41,063評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼改抡,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了系瓢?” 一聲冷哼從身側(cè)響起阿纤,我...
    開封第一講書人閱讀 39,991評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎夷陋,沒想到半個(gè)月后欠拾,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,522評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡骗绕,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,604評(píng)論 3 342
  • 正文 我和宋清朗相戀三年藐窄,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片酬土。...
    茶點(diǎn)故事閱讀 40,742評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡荆忍,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出撤缴,到底是詐尸還是另有隱情刹枉,我是刑警寧澤,帶...
    沈念sama閱讀 36,413評(píng)論 5 351
  • 正文 年R本政府宣布屈呕,位于F島的核電站微宝,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏虎眨。R本人自食惡果不足惜蟋软,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,094評(píng)論 3 335
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望嗽桩。 院中可真熱鬧岳守,春花似錦、人聲如沸碌冶。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,572評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽种樱。三九已至蒙袍,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間嫩挤,已是汗流浹背害幅。 一陣腳步聲響...
    開封第一講書人閱讀 33,671評(píng)論 1 274
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留岂昭,地道東北人以现。 一個(gè)月前我還...
    沈念sama閱讀 49,159評(píng)論 3 378
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親邑遏。 傳聞我的和親對(duì)象是個(gè)殘疾皇子佣赖,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,747評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容

  • 昨晚,同事約去唱歌记盒,人在健身房憎蛤,快速健完身趕過去,完事以后纪吮,雖不后悔俩檬,但真覺得沒意思 怎么說呢!大家聚一起就圖一樂...
    劉piano閱讀 90評(píng)論 0 0
  • 詩經(jīng)全文及譯文 《詩經(jīng)》現(xiàn)存詩歌305篇碾盟,包括西周初年到春秋中葉共 500 余年的民歌和朝廟樂章棚辽,分為風(fēng)、雅冰肴、頌三...
    觀茉閱讀 65,310評(píng)論 0 18
  • 分寸 做事情講究分寸屈藐,“過”和“不及”都要盡力避免的。我們提倡仁愛熙尉,但并不以喪失原則的仁愛之心去寬宥所有人的過...
    瑞雪兆豐2019閱讀 289評(píng)論 0 0
  • 那個(gè)女子联逻,是我一生的春色 (楔子) 那個(gè)女子滿身都是洗也洗不盡的春色 眸子閃處花花草草 笑口開時(shí)山山水水 但那塊發(fā)...
    DU億華閱讀 496評(píng)論 0 0
  • 分手了,可我還忘記不了他骡尽,即使分手是我提出來的遣妥,可是那不是我本意擅编,我只是想讓他挽留下我攀细,可誰知……也許,他沒有那么...
    甜蜜_f3b0閱讀 79評(píng)論 0 0