前面的安装及基础以后再更新。。。
一、动态路由及懒加载
1.在路由路径中使用 “动态路径参数”
⑴params
data:image/s3,"s3://crabby-images/af43b/af43bd24aec5dfe1787703e1657d9eff472ba84c" alt=""
data:image/s3,"s3://crabby-images/ad84b/ad84bce9fb78da548f0dbe77d812d952c7ad6883" alt=""
data:image/s3,"s3://crabby-images/824b2/824b297c8064acd203536f1f0d73f9167a1f9f29" alt=""
⑵query
data:image/s3,"s3://crabby-images/77832/778329bddcaba54ab03db5725ea4981858e1ee26" alt=""
data:image/s3,"s3://crabby-images/5ea53/5ea537b4cebf084b16bb088b55b0c79a53ab9bb3" alt=""
data:image/s3,"s3://crabby-images/b5b11/b5b11e7b6100c9d945e54af22cf566c5637b6f56" alt=""
data:image/s3,"s3://crabby-images/d50a5/d50a533ae757eb3913e0ecef4af6e35f8ad2f0e0" alt=""
注意:如果提供了 path,params 会被忽略, query 不属于这种情况。
https://blog.csdn.net/mf_717714/article/details/81945218(params和query的区别)
2.动态添加路由(router.addRoutes)
router.addRoutes( routes )
动态添加更多的路由规则:参数必须是一个符合 routes 选项要求的数组。(如图)
data:image/s3,"s3://crabby-images/4211a/4211abb71182989f9c4a2a6c645a3213482a2881" alt=""
3.路由懒加载
当打包构建应用时,Javascript 包会变得非常大,影响页面加载。如果我们能把不同路由对应的组件分割成不同的代码块,然后当路由被访问的时候才加载对应组件,这样就更加高效了。
结合 Vue 的异步组件和 Webpack 的代码分割功能,轻松实现路由组件的懒加载。
data:image/s3,"s3://crabby-images/88efb/88efb7de4e8332769b017848becf8fb716810ea3" alt=""
data:image/s3,"s3://crabby-images/7bc17/7bc17099b7f797c2d4aa4460c110731e26e5040b" alt=""
data:image/s3,"s3://crabby-images/57fa6/57fa664813bbaf68ce7e2b4e74212e81f7752946" alt=""
二、重定向
重定向也是通过 routes 配置来完成
data:image/s3,"s3://crabby-images/a0d0d/a0d0d57e8931654bae75d41f30076c4cf41a6047" alt=""
data:image/s3,"s3://crabby-images/50785/5078523139fa0fbb7e7f934de168461a58c7ed5a" alt=""
data:image/s3,"s3://crabby-images/b5120/b512012a4b60899ecb2fc8223b8ed3465d06d126" alt=""
注意:导航守卫并没有应用在跳转路由 ‘/a’ 上,而仅仅应用在其目标上(重定向的新路由)。为 ‘/a’ 路由添加一个 beforeEach 或 beforeLeave 守卫并不会有任何效果。
三、编程式导航
data:image/s3,"s3://crabby-images/f0441/f044121486bcbb71bb9d0ddf194b94856eebb42c" alt=""
该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如:
data:image/s3,"s3://crabby-images/b8144/b8144d65d15b0c0e0d57b8d1332f1278b77045b3" alt=""
data:image/s3,"s3://crabby-images/955fb/955fb78e85cd9bf1c10c97554444baf147fc254d" alt=""
想要导航到不同的 URL,则使用 router.push 方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。
注意:在 Vue 实例内部,你可以通过 $router 访问路由实例。因此你可以调用 this.$router.push。
四、路由的滚动行为
当创建一个 Router 实例,你可以提供一个 scrollBehavior 方法:
data:image/s3,"s3://crabby-images/678cd/678cdf1c64bed48d26c0c4f626a9b1861de1cfbc" alt=""
scrollBehavior 方法接收 to 和 from 路由对象。
第三个参数 savedPosition 当且仅当 popstate导航 (通过浏览器的 前进/后退 按钮触发) 时才可用。
这个方法返回滚动位置的对象信息,长这样:
五、精确匹配与模糊匹配
#linkActiveClass(模糊匹配)
类型: string
默认值: "router-link-active"
全局配置 <router-link> 的默认“激活 class 类名”。参考 router-link。
#linkExactActiveClass(精确匹配)
类型: string
默认值: "router-link-exact-active"
全局配置 <router-link> 精确激活的默认的 class。可同时翻阅 router-link。
网友评论