Vue中在新窗口打开页面及Vue-router的使用


Posted in Javascript onJune 13, 2018

背景

在开发提分加项目的过程中,遇到了点击下拉菜单时在新窗口中打开页面,由于之前一直做的是单页面应用,没有碰到过类似的需求,于是上网搜了一下解决办法,也再次系统地温习了一下vue-router。

Vue中在新窗口打开页面及Vue-router的使用

Vue中在新窗口打开页面及Vue-router的使用

解决

使用路由对象的resolve方法解析路由,可以得到location、router、href等目标路由的信息。得到href就可以使用window.open开新窗口了。

const {href} = this.$router.resolve({
 name: "statistics-explain",
 params: {
 classID: id,
 examSubjectID: this.planClassData.examSubjectID,
 studentStatus: 0
 }
});
window.open(href, '_blank');

延伸

参考文章:Vue Router

•动态路由匹配:一个“路径参数”使用冒号:标记。当匹配到一个路由时,参数值会被设置到this.$route.params,可以在每个组件内使用。

•嵌套路由:要在嵌套的出口中渲染组件,需要在 VueRouter 的参数中使用 children 配置,要注意,以 / 开头的嵌套路径会被当作根路径。 这让你充分的使用嵌套组件而无须设置嵌套的路径。

export default {
path: '/scoreplus',
name: 'scoreplus',
component: { template: '<router-view />' },
redirect: { name: 'scoreplus-index' },
children: [
 {
 // 查看个人方案
 path: 'preview/:examSubjectID/:xuexinID/:recordsID/:constitute/:planID',
 name: 'score-preview',
 meta: { text: '个人方案' },
 component: ScorePreview
 },
 {
 // 查看方案内容
 path: 'planList/:planID',
 name: 'score-plan-list',
 meta: { text: '查看方案内容' },
 component: ScorePlanList
 },
 {
 // 下载方案内容
 path: 'download/:planID/:classID',
 name: 'score-download-list',
 meta: { text: '下载方案内容' },
 component: DownloadList
 },
 {
 // 查看推送试题
 path: 'push/:planID/:level',
 name: 'score-question-push',
 meta: { text: '查看推送试题' },
 component: QuestionPush
 },
 {
 // 提分方案首页
 path: '',
 name: 'scoreplus-index',
 component: ScoreIndex
 }
]
}

•编程式导航

1.router.push(location, onComplete?, onAbort?):想要导航到不同的 URL,则使用 router.push 方法。这个方法会向 history 栈添加一个新的记录,所以,当用户点击浏览器后退按钮时,则回到之前的 URL。

// 字符串
router.push('home')
// 对象
router.push({ path: 'home' })
// 命名的路由
router.push({ name: 'user', params: { userId: 123 }})
// 带查询参数,变成 /register?plan=private
router.push({ path: 'register', query: { plan: 'private' }})

在 2.2.0+,可选的在 router.push 或 router.replace 中提供 onComplete 和 onAbort 回调作为第二个和第三个参数。这些回调将会在导航成功完成 (在所有的异步钩子被解析之后) 或终止 (导航到相同的路由、或在当前导航完成之前导航到另一个不同的路由) 的时候进行相应的调用。

2.router.replace(location, onComplete?, onAbort?):跟 router.push 很像,唯一的不同就是,它不会向 history 添加新记录,而是跟它的方法名一样 —— 替换掉当前的 history 记录。

3.router.go(n):这个方法的参数是一个整数,意思是在 history 记录中向前或者后退多少步,类似 window.history.go(n)。

•命名路由:可以在创建 Router 实例的时候,在 routes 配置中给某个路由设置名称。要链接到一个命名路由,可以给 router-link 的 to 属性传一个对象。

<router-link :to="{ name: 'user', params: { userId: 123 }}">User</router-link>
router.push({ name: 'user', params: { userId: 123 }})

•重定向和别名

1.重定向(redirect):

const router = new VueRouter({
 routes: [
 { path: '/a', redirect: '/b' }
 ]
 })

2.别名:/a 的别名是 /b,意味着,当用户访问 /b 时,URL 会保持为 /b,但是路由匹配则为 /a,就像用户访问 /a 一样。

const router = new VueRouter({
 routes: [
 { path: '/a', component: A, alias: '/b' }
 ]
 })

总结

以上所述是小编给大家介绍的Vue中在新窗口打开页面及Vue-router的 使用,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
初探jquery——表单应用范例
Feb 20 Javascript
不用AJAX和IFRAME,说说真正意义上的ASP+JS无刷新技术
Sep 25 Javascript
JQuery Highcharts 动态生成图表的方法
Nov 15 Javascript
javascript移动设备Web开发中对touch事件的封装实例
Jun 05 Javascript
javascript处理a标签超链接默认事件的方法
Jun 29 Javascript
Angular.js与node.js项目里用cookie校验账户登录详解
Feb 22 Javascript
使用原生js写ajax实例(推荐)
May 31 Javascript
在vue-cli中组件通信的方法
Dec 16 Javascript
vue的.vue文件是怎么run起来的(vue-loader)
Dec 10 Javascript
js tab栏切换代码实例解析
Sep 03 Javascript
Nuxt默认模板、默认布局和自定义错误页面的实现
May 11 Javascript
带你使用webpack快速构建web项目的方法
Nov 12 Javascript
微信小程序支付功能 php后台对接完整代码分享
Jun 12 #Javascript
js replace 全局替换的操作方法
Jun 12 #Javascript
微信小程序自定义prompt组件步骤详解
Jun 12 #Javascript
js实现购物车功能
Jun 12 #Javascript
浅谈Node.js 中间件模式
Jun 12 #Javascript
浅谈Webpack打包优化技巧
Jun 12 #Javascript
关于TypeScript模块导入的那些事
Jun 12 #Javascript
You might like
在任意字符集下正常显示网页的方法一
2007/04/01 PHP
Yii框架扩展CGridView增加导出CSV功能的方法
2017/05/24 PHP
jquery关于页面焦点的定位(文本框获取焦点时改变样式 )
2010/09/10 Javascript
js 获取和设置css3 属性值的实现方法
2013/05/06 Javascript
javascript中创建对象的几种方法总结
2013/11/01 Javascript
实现图片预加载的三大方法及优缺点分析
2014/11/19 Javascript
使用VS开发 Node.js指南
2015/01/06 Javascript
Javascript 正则表达式实现为数字添加千位分隔符
2015/03/10 Javascript
深入JavaScript高级程序设计之对象、数组(栈方法,队列方法,重排序方法,迭代方法)
2015/12/01 Javascript
ES6中如何使用Set和WeakSet
2016/03/10 Javascript
jQuery可见性过滤选择器用法示例
2016/09/09 Javascript
jQuery实现倒计时重新发送短信验证码功能示例
2017/01/12 Javascript
js实现华丽的九九乘法表效果
2017/03/29 Javascript
JS 60秒后重新发送验证码的实例讲解
2017/07/26 Javascript
JS使用tofixed与round处理数据四舍五入的区别
2017/10/25 Javascript
让你5分钟掌握9个JavaScript小技巧
2018/06/09 Javascript
详解angular2如何手动点击特定元素上的点击事件
2018/10/16 Javascript
玩转Koa之koa-router原理解析
2018/12/29 Javascript
React实现全选功能
2020/08/25 Javascript
js实现验证码干扰(动态)
2021/02/23 Javascript
[04:48]DOTA2亚洲邀请赛林书豪为VGJ加油
2017/04/01 DOTA
asyncio 的 coroutine对象 与 Future对象使用指南
2016/09/11 Python
Android分包MultiDex策略详解
2017/10/30 Python
python奇偶行分开存储实现代码
2018/03/19 Python
python对excel文档去重及求和的实例
2018/04/18 Python
Python 输入一个数字判断成绩分数等级的方法
2018/11/15 Python
python读取txt文件中特定位置字符的方法
2018/12/24 Python
浅谈PyQt5 的帮助文档查找方法,可以查看每个类的方法
2019/06/25 Python
OpenCV模板匹配matchTemplate的实现
2019/10/18 Python
解决pytorch报错:AssertionError: Invalid device id的问题
2020/01/10 Python
CSS3弹性伸缩布局之box布局
2016/07/12 HTML / CSS
本科毕业生的求职信范文
2013/11/20 职场文书
护士毕业实习感言
2014/03/05 职场文书
给女朋友的道歉短信
2015/05/12 职场文书
「SHOW BY ROCK!!」“雫シークレットマインド”组合单曲MV公开
2022/03/21 日漫
MySQL脏读,幻读和不可重复读
2022/05/11 MySQL