node.js - antdesign怎么集合react-redux對(duì)input控件進(jìn)行初始化賦值
問題描述
https://segmentfault.com/q/10...https://segmentfault.com/q/10...對(duì)于這兩個(gè)帖子問題的原因已經(jīng)找到了,原來是因?yàn)閞eact-redux,進(jìn)行頁面加載的時(shí)候,會(huì)先把原來的標(biāo)簽加載一次,然后再執(zhí)行componentDidMount事件
ps.我也試過了componentWillMount事件,結(jié)果相同。執(zhí)行順序(詳):1.在第一次加載的時(shí)候,ant控件Input的defaultValue已經(jīng)被賦值了,只不過沒有找到,所以是undefined
2.然后執(zhí)行componentDidMount/componentWillMount時(shí)間,在把ss重新賦值,賦予給Input的defaultValue
我再控制臺(tái)也輸出了ss,由結(jié)果也可以驗(yàn)證上面的結(jié)論
看吧這一對(duì)是不是輸出了兩次?而我在代碼中只寫了一次
按照input的描述,頁面只有在第一次給input賦值的時(shí)候會(huì)把value值顯示在頁面上,后面不管在頁面上的控制臺(tái)更改幾次value都不會(huì)對(duì)頁面顯示產(chǎn)生影響,所以頁面一直都顯示空。
那么問題來了,我要怎樣做才能在react-redux的框架基礎(chǔ)上,并加入ant的標(biāo)簽,對(duì)Input進(jìn)行初始化賦值,并把這個(gè)賦值顯示在頁面上呢?
問題解答
回答1:render 是會(huì)在改變state的時(shí)候渲染 你第一次進(jìn)頁面 render一次 然后你請(qǐng)求數(shù)據(jù) 會(huì)改變state 會(huì)再render一次!
回答2:state和props的改變都會(huì)導(dǎo)致組件被渲染, 但是是否真的要渲染是取決于你的shouldComponentUpdate這個(gè)函數(shù)的,你可以通過實(shí)現(xiàn)這個(gè)函數(shù)來控制是否要渲染
相關(guān)文章:
1. debian - docker依賴的aufs-tools源碼哪里可以找到???2. dockerfile - 我用docker build的時(shí)候出現(xiàn)下邊問題 麻煩幫我看一下3. angular.js使用$resource服務(wù)把數(shù)據(jù)存入mongodb的問題。4. docker gitlab 如何git clone?5. docker 下面創(chuàng)建的IMAGE 他們的 ID 一樣?這個(gè)是怎么回事????6. macos - mac下docker如何設(shè)置代理7. javascript - 連續(xù)點(diǎn)擊觸發(fā)mouseleave事件8. docker網(wǎng)絡(luò)端口映射,沒有方便點(diǎn)的操作方法么?9. docker start -a dockername 老是卡住,什么情況?10. docker api 開發(fā)的端口怎么獲取?

網(wǎng)公網(wǎng)安備