uni-app中拦截Webview窗口URL请求的方法实现

本文将记录拦截Webview窗口URL请求的方法

前言

最近app中使用Webview展示网页时,为禁止其跳转打开手机其他app,需要对请求url进行判断拦截。

如:web-view显示淘宝优惠券网站,但这个网站常常会自动跳转打开淘宝app,那么就需要对跳转url进行判断拦截。

具体实现

首先了解uni-app中获取web-view对象

//方法一
const currentWebview = this.$mp.page.$getAppWebview(); 
//方法二
var pages = getCurrentPages();  
var page = pages[pages.length - 1]; 
var currentWebview = page.$getAppWebview(); 

拦截请求

var wv = currentWebview.children()[0];
// 拦截所有页面跳转,可使用参数拦截weibo.com域名之外的跳转({mode:'allow',match:'.*weibo\.com/.*'})
wv.overrideUrlLoading({mode: 'allow',match: '.*qq\.com/.*'}, function(e) {
	console.log('reject url: ' + e.url);
});

获取当前页面url

var pages = getCurrentPages();
var page = pages[pages.length - 1];
var currentWebview = page.$getAppWebview();
var url = currentWebview.children()[0].getURL();
console.log('=== url ===', url);
拦截webview请求

其他推荐:

admin

发表评论

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen: