返回的数据:
{
"type": "message",
"target": {},
"currentTarget": {},
"timeStamp": 1593413171731,
"detail": {
"data": [{
"action": "message",
"id": "2020",
"type": "copy"
}]
}
}
{
"action": "message",
"id": "2020",
"type": "copy"
}
<template>
<view>
<web-view title="hehe" :webview-styles="webviewStyles"
:src="url"
@message="message"
@onPostMessage = "onPostMessage">
</web-view>
</view>
</template>
<script>
var wv;
export default {
data() {
return {
webviewStyles: {
progress: {
color: '#3e3adc'
}
},
url:'',
}
},
onLoad() {
console.log('x')
var u_id = this.$userFind.u_id
console.log(u_id)
var data_old = this.$myApi.base64_encode_api(u_id)
var data = this.$myApi.base64_encode_api(data_old)
const url = 'http://myphpmy.vip/web/demo.html'
console.log(url)
this.url = url
},
onShow(){
},
methods:{
onPostMessage(){
console.log('xxxonPostMessage')
},
demo(){
console.log('xxxxxxxxxx')
},
message(event){
console.log('触发事件')
const data = event.detail.data[0]
console.log(data)
console.log('___________')
const action = data.action
console.log(action)
console.log('messagemessagemessagemessagemessage')
uni.showModal({
title: '提示',
content: data.type,
success: function (res) {
if (res.confirm) {
console.log('用户点击确定');
} else if (res.cancel) {
console.log('用户点击取消');
}
}
});
console.log(event)
console.log('xxx')
}
}
}
</script>
<style>
</style>
H5:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width,initial-scale=1,minimum-scale=1,maximum-scale=1,user-scalable=no" />
<title>网络网页</title>
<style type="text/css">
.btn {
display: block;
margin: 20px auto;
padding: 5px;
background-color:
border: 0;
color:
height: 40px;
width: 200px;
}
.btn-red {
background-color:
}
.btn-yellow {
background-color:
}
.desc {
padding: 10px;
color:
}
.post-message-section {
visibility: hidden;
}
</style>
</head>
<body>
<p class="desc">web-view 组件加载网络 html 示例。点击下列按钮,跳转至其它页面。</p>
<div class="btn-list">
<button class="btn" type="button" data-action="switchTab">switchTab</button>
</div>
<div class="post-message-section">
<p class="desc">网页向应用发送消息,注意:小程序端应用会在此页面后退时接收到消息。</p>
<div class="btn-list">
<button class="btn btn-red" type="button" id="postMessage">postMessage</button>
</div>
</div>
<script type="text/javascript">
var userAgent = navigator.userAgent;
if (userAgent.indexOf('AlipayClient') > -1) {
document.writeln('<script src="https://appx/web-view.min.js"' + '>' + '<' + '/' + 'script>');
} else if (/QQ/i.test(userAgent) && /miniProgram/i.test(userAgent)) {
document.write('<script type="text/javascript" src="https://qqq.gtimg.cn/miniprogram/webview_jssdk/qqjssdk-1.0.0.js"><\/script>');
} else if (/miniProgram/i.test(userAgent) && /micromessenger/i.test(userAgent)) {
document.write('<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.4.0.js"><\/script>');
} else if (/toutiaomicroapp/i.test(userAgent)) {
document.write('<script type="text/javascript" src="https://s3.pstatp.com/toutiao/tmajssdk/jssdk-1.0.1.js"><\/script>');
} else if (/swan/i.test(userAgent)) {
document.write('<script type="text/javascript" src="https://b.bdstatic.com/searchbox/icms/searchbox/js/swan-2.0.18.js"><\/script>');
} else if (/quickapp/i.test(userAgent)) {
document.write('<script type="text/javascript" src="https://quickapp/jssdk.webview.min.js"><\/script>');
}
if (!/toutiaomicroapp/i.test(userAgent)) {
document.querySelector('.post-message-section').style.visibility = 'visible';
}
</script>
<!-- uni 的 SDK -->
<script type="text/javascript" src="https://js.cdn.aliyun.dcloud.net.cn/dev/uni-app/uni.webview.1.5.2.js"></script>
<script type="text/javascript">
document.addEventListener('UniAppJSBridgeReady', function() {
document.querySelector('.btn-list').addEventListener('click', function(evt) {
var target = evt.target;
if (target.tagName === 'BUTTON') {
var action = target.getAttribute('data-action');
switch (action) {
case 'switchTab':
uni.switchTab({
url: '/pages/tabBar/API/API'
});
break;
case 'reLaunch':
uni.reLaunch({
url: '/pages/tabBar/component/component'
});
break;
case 'navigateBack':
uni.navigateBack({
delta: 1
});
break;
default:
uni[action]({
url: '/pages/component/button/button'
});
break;
}
}
});
document.getElementById('postMessage').addEventListener('click', function() {
uni.postMessage({
data: {
action: 'message',
id:'2020',
type:'copy'
}
});
});
});
</script>
</body>
</html>