uniapp webview web-view组件监听网页变化 url变化 与网页通讯

uniapp webview web-view组件监听网页变化 url变化 与网页通讯

需求是在app页面内嵌套自己的h5 或者别人的h5 切换页面时候获取到网页的变化 url的变动

第一种方法就是使用 html5+的方法

javascript 复制代码
//html部分
<web-view :src="webviewPath" class="webview" height="100%" :webview-styles="{width:'100%',height:'100%'}"
			id="webview" ></web-view>
//js部分	
<script>
export default {
onReady() {
// 获取当前Webview窗口对象
			const ws = plus.webview.currentWebview();
			var currentWebview = this.$scope.$getAppWebview()
			setTimeout(() => {
			let wv = currentWebview.children()[0];
			_this.ws.loadURL(_this.webviewPath) //加载h5链接
			// 监听窗口触屏事件
				_this.ws.addEventListener('touchstart', function(e) {
					setTimeout(() => {
						let orderUrl = _this.ws.getURL() //页面链接
						const wsTitle = _this.ws.getTitle() //页面标题
						console.log(_this.ws.getTitle())
						console.log(orderUrl)
						console.log('touchstart');
					}, 100)

				}, false);
				_this.ws.onloaded = () => {
					let orderUrl = _this.ws.getURL()
					console.log('onloaded事件加载完成', orderUrl)
				};
			},1000)//如果是页面初始化调用时,需要延时一下 
}
}
</script>

第二种方法就是使用 html5+的方法 和uniapp的 uni.webview.js

使用uni.webview.js 就可以实现h5和app通讯了,想要h5的任何数据都用通过 uni.webView.postMessage来传递给

app

javascript 复制代码
//html部分
<web-view :src="webviewPath" class="webview" height="100%" :webview-styles="{width:'100%',height:'100%'}"
			id="webview" @message="receiveMsg"></web-view>
	methods: {
			wsEvalJs() {
				// 在webview加载完成后,注入JavaScript代码
				this.ws.evalJSSync(`
				       var script = document.createElement('script');
				       script.src = 'https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js';
				       document.body.appendChild(script);
							 document.addEventListener("UniAppJSBridgeReady", function() {
							   console.log("初始化uniapp的API成功");
								 uni.webView.postMessage({ data: { type: "href",href:window.location.href,msg:"获取页面url" } });
							 });
				      `);
			},
				//接收wenview h5的消息
			receiveMsg(option){
				console.log('接收到的消息参数'+JSON.stringify(option))
				
			},
			}
相关推荐
QQ1__8115175154 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态4 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子4 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室4 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI4 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing4 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者4 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册4 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李5 小时前
2026 年 Web 前端开发的 8 个趋势!
前端
里欧跑得慢5 小时前
15. Web可访问性最佳实践:让每个用户都能平等访问
前端·css·flutter·web