官术网_书友最值得收藏!

Recognizing states

Next, the router will derive a router state from the URL. To understand how this phase works, we need to learn a bit about how the router matches the URL.

The router goes through the array of routes, one by one, checking if the URL starts with a route's path. Here it will check that /inbox/33/messages/44 starts with :folder. It does, since :folder is what is called a variable segment. It is a parameter where normally you'd expect to find a constant string. Since it is a variable, virtually any string will match it. In our case inbox will match it. So the router will set the folder parameter to inbox, then it will take the children configuration items, the rest of the URL 33/messages/44, and will carry on matching. As a result, the id parameter will be set to 33, and, finally, the messages/:id route will be matched with the second id parameter set to 44.

If the taken path through the configuration does not "consume" the whole URL, the router backtracks to try an alternative path. If it is impossible to match the whole URL, the navigation fails. But if it works, the router state representing the future state of the application will be constructed.

A router state consists of activated routes. And each activated route can be associated with a component. Also, note that we always have an activated route associated with the root component of the application.

主站蜘蛛池模板: 文山县| 江津市| 阳高县| 新乡市| 腾冲县| 临夏县| 英吉沙县| 云安县| 武山县| 井陉县| 汤原县| 长子县| 永仁县| 香港| 镇江市| 安康市| 金塔县| 贵港市| 苏州市| 桐梓县| 那坡县| 高唐县| 建阳市| 时尚| 靖远县| 焦作市| 河北省| 洪湖市| 克什克腾旗| 天祝| 都江堰市| 万载县| 军事| 革吉县| 丰台区| 南川市| 永济市| 营山县| 友谊县| 德钦县| 高阳县|