Vue-router总结
来源:互联网 发布:手机数据魔方 编辑:程序博客网 时间:2024/05/21 05:24
引用Vue-router 官方说明:
用 Vue.js + vue-router 创建单页应用,是非常简单的。使用 Vue.js 时,我们就已经把组件组合成一个应用了,当你要把 vue-router 加进来,只需要配置组件和路由映射,然后告诉 vue-router 在哪里渲染它们。
基础部分大概分为以下几大块:
- 动态路由匹配
- 嵌套路由
- 编程式导航
- 命名路由
- 命名视图
- 重定向 和 别名
- HTML5 History 模式
- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
- --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
- 编程 式导航
router.push(location)
想要导航到不同的 URL,则使用
router.push
方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。当你点击
<router-link>
时,这个方法会在内部调用,所以说,点击<router-link :to="...">
等同于调用router.push(...)
。声明式 编程式 <router-link :to="...">
router.push(...)
该方法的参数可以是一个字符串路径,或者一个描述地址的对象。例如:
// 字符串router.push('home')// 对象router.push({ path: 'home' })// 命名的路由router.push({ name: 'user', params: { userId: 123 }})// 带查询参数,变成 /register?plan=privaterouter.push({ path: 'register', query: { plan: 'private' }})
router.replace(location)
跟
router.push
很像,唯一的不同就是,它不会向 history 添加新记录,而是跟它的方法名一样 —— 替换掉当前的 history 记录。声明式 编程式 <router-link :to="..." replace>
router.replace(...)
router.go(n)
这个方法的参数是一个整数,意思是在 history 记录中向前或者后退多少步,类似
window.history.go(n)
。例子
// 在浏览器记录中前进一步,等同于 history.forward()router.go(1)// 后退一步记录,等同于 history.back()router.go(-1)// 前进 3 步记录router.go(3)// 如果 history 记录不够用,那就默默地失败呗router.go(-100)router.go(100)
操作 History
你也许注意到
router.push
、router.replace
和router.go
跟window.history.pushState
、window.history.replaceState
和window.history.go
好像, 实际上它们确实是效仿window.history
API 的。因此,如果你已经熟悉 Browser History APIs,那么在 vue-router 中操作 history 就是超级简单的。
还有值得提及的,vue-router 的导航方法 (
总结:使用编程式导航时,必须是 name 和 params一起使用,path和query一起使用(例如:push
、replace
、go
) 在各类路由模式(history
、hash
和abstract
)下表现一致。- // 命名的路由
- router.push({ name: 'user', params: { userId:123 }})
- // 带查询参数,变成 /register?plan=private
- router.push({ path: 'register', query: { plan:'private' }})
- )
- vue-router总结
- vue-router总结
- Vue-router总结
- vue-router总结
- vue-router 知识总结
- vue-router总结
- vue-router使用总结
- Vue-Router总结
- vue-router
- vue-router
- vue-router
- vue-router
- Vue router
- vue-router
- vue-router
- vue-router
- vue-router
- vue-router
- 常见错误
- java.langNoClassdefFoundError & java.lang.ClassNotFoundException
- ubuntu锁屏后,字符密码无法输入
- Swift3字符串转换为其他数据类型
- 重构:改善既有代码的设计
- Vue-router总结
- 选择排序(Selection Sort)
- 2132: 中南大学2017年ACM暑期集训前期训练题集(入门题)
- 接口和抽象区别的升华
- 图像抠图闭合方案 A Closed Form Solution to Natural Image Matting
- 欢迎使用CSDN-markdown编辑器
- Xshell使用教程——问答方式
- CSS思维导图总结二
- Java入门学习-理解float,double,unsigned,long,short,final,extends,implements的用法。