什么是前端路由?
路由是根据不同的url地址展示不同的内容或页面
前端路由就是把不同路由对应不同的内容或者页面的任务交给前端来做,之前是通过服务器根据url的不同返回不同的页面
什么时候使用
单页面应用程序,大部分页面结构不变,变动部分结构
优点与缺点
优点:用户体验好,不需要每次从服务器全部获取,快速展示给用户
缺点:不利于SEO,
使用浏览器的前进,后退会重新发送请求,没有合理利用缓存
单页面无法记住之前的滚动位置,无法在前进后退是定到之前对应的位置
首次加载缓慢
vue-router用来构建SPA 单页Web应用(single page web application,SPA)
<router-link></router-link>跳到指定的路由 (类似于a标签) 或者this.$router.push({path:''}) //通过代码方式进行页面调整
<router-view></router-view> 指令渲染
动态路由匹配
data:image/s3,"s3://crabby-images/5fe51/5fe518ee5d8e03ab14d2d08527ccdd30b609b9ab" alt=""
data:image/s3,"s3://crabby-images/6201c/6201c7044b0132ac4e43339e0f584adde1c14614" alt=""
:goodsId :name 就是动态输入值 访问如下
http://localhost:8080/#/goods/23424/user/shasha
可以在页面显示路由内容 主语这里是route 不是 router
data:image/s3,"s3://crabby-images/b5a16/b5a1685f39371aa81b25ec33f5633bc3cee473c9" alt=""
嵌套路由
路由里面嵌套路由,使用情形 左侧菜单 右侧内容展示
路由配置子路由
data:image/s3,"s3://crabby-images/96a4b/96a4b381d2e146d79345c43fc84e9884425a73e9" alt=""
页面使用
data:image/s3,"s3://crabby-images/fd3e5/fd3e5530fbd1d55096191355229eebfe287b4709" alt=""
编程式路由
通过js来实现页面的跳转
$router.push("name");
$router.push({path:"name"});
$router.push({path:"name?a=123"});或者$router.push({path:"name",query:{a:123}})
$router.go(1) 类似于history.go 功能
data:image/s3,"s3://crabby-images/57b31/57b31e0ab5b504783705763a5728c56d80f257f4" alt=""
页面怎么获取到传递的参数
data:image/s3,"s3://crabby-images/c3723/c372393516879d3673f01d1cf8246b2f4c313607" alt=""
注意:
$route.params.goodsId params是动态路由传递参数
$route.query .goodsId query组件切换路由与路由之间的参数传递
命名路由和命名视图
给路由定义不同的名字,根据名字进行匹配
给不同的router-view定义名字。通过名字进行对应组件的渲染
router/index.js
data:image/s3,"s3://crabby-images/a472c/a472ca1fad8c80fe5c617509fafd436b0e6cfc74" alt=""
App.vue
data:image/s3,"s3://crabby-images/7c281/7c281d98c09f859a0b0ec3c85cc54b93b11f9c4d" alt=""
显示效果
data:image/s3,"s3://crabby-images/420fa/420fa6f514b799e5dee77322cee1ec6f9d026fe3" alt=""
网友评论