網站左側導航中點擊link跳轉路由,在一個路由中不同的操作會寫渲染不同的組件,想在重新點擊左側導航時重新渲染為最初的組件,該如何做;
<Link to="/a">個人資料</a>
組件a中不同的操作,會根據判斷渲染不同的組件,我在渲染到第二個組件的時候,用戶重新點擊左側導航想從新走生命周期渲染默認的第一個組件
使用react-router的createElement
解決!
Router.js
......
...... // 省略其他無關緊要代碼
// 此處為要點擊刷新的組件
const arr = [
home
];
// 開關優(yōu)化
let onOff =false;
// 頁面強制刷新,如果需要強制刷新在路由中添加onChange事件以及在組件數組添加
const createElement=(component, props) =>{
if (props.children && onOff || props.children && arr.includes(props.routes.slice(-1)[0].getComponent)) {
let children = Object.assign({}, props.children, {key : `${window.location.pathname}` + new Date().getTime()})
props = { ...props, children };
onOff = false;
}
return React.createElement(component, props)
}
const onChange = (props, next) => {
onOff = true
console.log(`${next.location.pathname}`, 'change');
}
const RouteConfig = (
<Router history={history} createElement = {createElement}>
<Route path="/home" getComponent={home} onChange = {onChange} />
...
...
</Router>
);
export default RouteConfig;
如果您用的react-router4.0,當使用 component 時,router 將使用 React.createElement 根據給定的 component 創(chuàng)建一個新的 React 元素。這意味著如果你使用內聯函數(inline function)傳值給 component將會產生不必要的重復裝載。對于內聯渲染(inline rendering), 建議使用 renderprop。
也可以參考下我新寫的文章:這里有沒有你想要的react-router
北大青鳥APTECH成立于1999年。依托北京大學優(yōu)質雄厚的教育資源和背景,秉承“教育改變生活”的發(fā)展理念,致力于培養(yǎng)中國IT技能型緊缺人才,是大數據專業(yè)的國家
北大青鳥中博軟件學院創(chuàng)立于2003年,作為華東區(qū)著名互聯網學院和江蘇省首批服務外包人才培訓基地,中博成功培育了近30000名軟件工程師走向高薪崗位,合作企業(yè)超4
中公教育集團創(chuàng)建于1999年,經過二十年潛心發(fā)展,已由一家北大畢業(yè)生自主創(chuàng)業(yè)的信息技術與教育服務機構,發(fā)展為教育服務業(yè)的綜合性企業(yè)集團,成為集合面授教學培訓、網
達內教育集團成立于2002年,是一家由留學海歸創(chuàng)辦的高端職業(yè)教育培訓機構,是中國一站式人才培養(yǎng)平臺、一站式人才輸送平臺。2014年4月3日在美國成功上市,融資1
曾工作于聯想擔任系統開發(fā)工程師,曾在博彥科技股份有限公司擔任項目經理從事移動互聯網管理及研發(fā)工作,曾創(chuàng)辦藍懿科技有限責任公司從事總經理職務負責iOS教學及管理工作。
浪潮集團項目經理。精通Java與.NET 技術, 熟練的跨平臺面向對象開發(fā)經驗,技術功底深厚。 授課風格 授課風格清新自然、條理清晰、主次分明、重點難點突出、引人入勝。
精通HTML5和CSS3;Javascript及主流js庫,具有快速界面開發(fā)的能力,對瀏覽器兼容性、前端性能優(yōu)化等有深入理解。精通網頁制作和網頁游戲開發(fā)。
具有10 年的Java 企業(yè)應用開發(fā)經驗。曾經歷任德國Software AG 技術顧問,美國Dachieve 系統架構師,美國AngelEngineers Inc. 系統架構師。