vue路由跳轉打開新窗口(window.open())和關閉窗口(window.close())
vue路由跳轉打開新窗口和關閉窗口
需求:從當前頁面跳轉到其他頁面時,打開一個新窗口
比如:點擊頁面上的用戶反饋,打開用戶反饋的新頁面,要使用編程式導航
編程式導航
使用路由對象的resolve的方法解析路由,可以得到location、router、href等目標路由的信息,隻要得到href就可以使用window.open打開新窗口瞭。
代碼如下:
// 路由跳轉新界面 userFeedback() { // this.$router.push({ path: '/feedback' }); 用push,也能實現跳轉,但是不能打開新頁面。 const { href } = this.$router.resolve({ path: '/feedback' }); window.open(href, '_blank'); },
如果是復雜的需要帶參數跳轉的路由,是以下寫法,用query攜帶參數
<template slot-scope="scope"> <el-button size="small" @click.stop="watchDetail(scope.row)">詳情</el-button> </template>
watchDetail(row) { const { href } = this.$router.resolve({ path: `/answerSituation`, query: { id: row.id, paperName: this.paperName, name: row.name, examScore: row.examScore, answersTime: row.answersTime } }); window.open(href, '_blank'); }
window.open( )方法
定義和用法
open() 方法用於打開一個新的瀏覽器窗口或查找一個已命名的窗口。
語法
window.open(URL,name,specs,replace)
第一個參數URL
可選。打開指定的頁面的URL。如果沒有指定URL,打開一個新的空白窗口
第二個參數name
可選。指定target屬性或窗口的名稱。支持以下值:
_blank
– 在新窗口顯示目標網頁。這是默認_self
– 在當前窗口顯示目標網頁_top
– 框架網頁中在上部窗口中顯示目標網頁(不常用)
第三個參數
可選參數,設置窗口參數,各參數用逗號隔開。
關閉窗口 window.close()
用法
window.close(); //關閉本窗口 或者 <窗口對象>.close(); //關閉指定的窗口
例子:關閉新窗口
var mywin=window.open('http://www.xxx.com'); //將新打的窗口對象,存儲在變量mywin中 mywin.close();
vue路由跳轉打開新窗口(被瀏覽器攔截)
今天做瞭一個功能是點擊按鈕路由跳轉打開新的窗口頁面
第一種方法
<router-link target="_blank" :to="{path:'/FundManger/FundProductMoney', query:{managerId:fundcode}}></router-link>"
第二種方法
<a @click="getGetMyPortfolioById(scope.row) ">查看</a> getGetMyPortfolioById(vals) { getMyPortfolioById({ }).then(response = >{ const routerdata = this.$router.resolve({ name: '組合分析以及組合持倉', params: { managerId: vals.fundCode } }) const newhref = routerdata.href + '?managerId=' + vals.fundCode window.open(newhref, '_blank') }) }
當我們用到第二種方法時候,是觸發事件請求接口根據條件去判斷在進行路由跳轉,這個時候就會遇到瀏覽器被攔截的問題
在接口請求的回調函數中 需要使用window.open()打開新頁面,但是等接口請求成功之後,window.open()打開新頁面總是被瀏覽器攔截,原因大概是,放在請求回調函數中的操作,被瀏覽器認為不是用戶主動觸發的事件,並且延遲1000ms ,被認為有可能是廣告,於是被攔截
解決的方法:
在接口請求之前先打開一個空的頁面
let tempPage=window.open('' ", _blank');
然後在回調函數中,
tempPage.location=url;
第二種方法(改良版)
<a @click="getGetMyPortfolioById(scope.row) ">查看</a> getGetMyPortfolioById(vals) { const tempPage = window.open('', '_blank') getMyPortfolioById({}).then(response = >{ const routerdata = this.$router.resolve({ name: '組合分析以及組合持倉', params: { managerId: vals.fundCode } }) const newhref = routerdata.href + '?managerId=' + vals.fundCode tempPage.location = newhref }) }
總結
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。
推薦閱讀:
- vue打開新窗口並實現傳參的圖文實例
- JavaScript Window 打開新窗口(window.location.href、window.open、window.showModalDialog)
- vue中如何下載excel流文件及設置下載文件名
- vue跳轉同一個路由參數不同的問題
- vue.js管理後臺table組件封裝的方法