# 嚴格模式
## 改造案例
我們可以發現下面的入口文件中我們將**新聞中心**和**新聞1**都寫出來了,那么會出現什么效果呢?
```
<HashRouter>
{/*導航 Link Vue的用法很相似 注意這里是大寫*/}
<Link to={"/home"}>首頁</Link>
<Link to={"/about"}>關于</Link>
<Link to={"/news"}>新聞中心</Link>
<Link to={"/news/1"}>新聞1</Link>
<hr/>
{/*路由指向哪個頁面 (組件)有兩個意義 定義路由指向 在哪個位置顯示頁面*/}
<Route path={'/home'} component={Home}/>
<Route path={'/about'} component={About}/>
<Route path={'/news'} component={NewsCenter}/>
<Route path={'/news/:id'} component={News}/>
</HashRouter>
```
## 問題呈現

我們發現在單擊**新聞中心**時只顯示**新聞中心**的頁面,而單擊**新聞1**時它顯示的不僅僅是**新聞1**對應的頁面而且還把**新聞中心**的頁面也顯示出來了。這是為什么?
這是因為路由的匹配規則決定的。在單擊新聞中心時 路由只能匹配自己。
而在單擊新聞1時,它的路由是news/1 而新聞中心的路由是news,把新聞中心的路由包含進去了,所以也匹配到了。那么就顯示出來了。
## 解決問題
工作中我們一般是希望只顯示自己對應的頁面信息,其它的頁面信息是不顯示的,如何解決?這時我們要借助于嚴格路由來進行解決。
```
<Route path={'/news'} component={NewsCenter} exact/>
<Route path={'/news/:id'} component={News} exact/>
```

- webpack復習
- React基礎
- 前端三大主流框架對比
- React中幾個核心的概念
- React基礎語法
- React JSX語法
- React組件
- 普通組件
- 組件通信-父向子傳遞
- 組件拆成單個文件
- 面向對象復習
- Class組件基礎
- Class組件的私有狀態(私有數據)
- 案例:實現評論列表組件
- 組件樣式管理
- 組件樣式分離-樣式表
- CSS模塊化
- 生命周期
- React組件生命周期
- Counter組件來學習組件生命周期
- 生命周期總結
- 生命周期案例
- React評論列表
- React雙向數據綁定
- React版todolist
- 其它提高(了解)
- 組件默認值和數據類型驗證
- 綁定this并傳參的三種方式
- 祖孫級和非父子組件傳遞數據(了解)
- React路由
- 路由基礎
- 動態路由
- 路由嚴格模式
- 路由導航定位
- 路由重定向
- 路由懶加載
- WolfMovie項目
- 項目初始化
- AntDesign使用
- 其它相關了解