3.1 nvue 页面替代 vue 页面
nvue文件webview使用方式如下:
//nvue 中的webview需要自行设置宽高否则无法展示<template>
<view>
<web-view ref="webview" src="/hybrid/html/local.html" style="width: 500px;height: 600px;" @onPostMessage="getMessage"></web-view>
</view>
</template>
<script>
export default {
data(){
return {
}
},
onLoad() {
setTimeout(()=>{
this.handlePostMessage('测试传参')
},200)
},
methods: {
handlePostMessage(res) {
this.$refs.webview.evalJs(`handleMessage()`);
},
getMessage(e) {
uni.showModal({
content: JSON.stringify(e.detail),
showCancel: false
})
}
}
}
</script>
h5页面内容如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1">
<title>本地网页</title>
<style type="text/css">
.btn {
display: block;
margin: 20px auto;
padding: 5px;
background-color: #007aff;
border: 0;
color: #ffffff;
height: 40px;
width: 200px;
}
.btn-red {
background-color: #dd524d;
}
.btn-yellow {
background-color: #f0ad4e;
}
.desc {
padding: 10px;
color: #999999;
}
</style>
</head>
<body>
<p class="desc">web-view 组件加载本地 html 示例,仅在 App 环境下生效。点击下列按钮,跳转至其它页面。</p>
<div class="btn-list">
<button class="btn" type="button" data-action="navigateTo">navigateTo</button>
<button class="btn" type="button" data-action="redirectTo">redirectTo</button>
<button class="btn" type="button" data-action="navigateBack">navigateBack</button>
<button class="btn" type="button" data-action="reLaunch">reLaunch</button>
<button class="btn" type="button" data-action="switchTab">switchTab</button>
</div>
<p class="desc" id="lizhao">网页向应用发送消息。注意:小程序端应用会在此页面后退时接收到消息。</p>
<div class="btn-list">
<button class="btn btn-red" type="button" id="postMessage">postMessage</button>
</div>
<!-- uni 的 SDK -->
<script type="text/javascript" src="https://unpkg.com/@dcloudio/uni-webview-js@0.0.1/index.js"></script>
<script type="text/javascript">
window.handleMessage=function(data){
alert('传来的参数'+data)
}
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/API/API'
});
break;
case 'navigateBack':
uni.navigateBack({
delta: 1
});
break;
default:
uni[action]({
url: '/pages/component/button/button'
});
break;
}
}
});
document.querySelector("#postMessage").addEventListener('click', function() {
uni.postMessage({
data: {
action: 'message888888'
}
});
})
});
</script>
</body>
</html>
注意⚠️:uni-app 中的 nvue 页面问题
nvue 页面不使用 webview 渲染,但其中的web-view组件说明如下:
nvue的weex 组件模式:weex模式下的web-view组件是weex自己实现的,它目前仍然使用UIWebview。官方会追踪weex的升级。nvue的uni-app组件模式:web-view组件使用WKWebview,不可修改为uiWebview。
3.2 白屏检测刷新
3.2.1 自动刷新
- 需要一个全局挂载的工具类,
Vue.prototype.$utils = utils - 在需要使用的页面(一般为tab页)最外层需要设置为同一个class名称;
- 在
onshow方法调用;
let pageList = {};
const utils = {
reloadCurrentPage: function(\_self, isTab = true) {
// #ifdef APP-PLUS
// 获取当前路由及传参,以备页面刷新之用
var route = _self.$scope.route;
var data = _self.$scope.options && _self.$scope.options.data;
var url = '/' + route;
if (data) {
url = '/' + route + '?data=' + data;
}
var isRecovery = true; // 页面刷新标识
let newTime = Date.now();
if (pageList[url]) {
const query = uni.createSelectorQuery().in(_self);
//这里select()中替换为自己的样式class名称
query.select('.container').fields({size:true}, data => {
isRecovery = false; // 重置页面刷新标识
}).exec();
setTimeout(() => {
// 页面白屏,需触发刷新机制
if (isRecovery) {
//如果获取不到节点
//确保只刷新一次
if (newTime - pageList[url] > 3000) {
//超过3秒才重新刷新,这里设置几秒就行,目的是防止无限刷新
//因为刷新后页面肯定会出来,但是立马再次调用该方法不一定能获取节点(DOM树未必构建完毕)
pageList[url] = newTime;
// 若为tab标签栏位
if (isTab) {
uni.reLaunch({
url
})
} else {
// 若为页面
uni.redirectTo({
url
})
}
}
}
}, 600)
} else {
// 页面正常,记录当前时间
pageList[url] = newTime;
}
// if (plus.os.name === 'iOS') {
// }
// #endif
}
}
3.2.2 手动刷新
webview页面提供按钮以支持用户手动刷新,
手动刷新实现逻辑如下:
最后
前端CSS面试题文档,JavaScript面试题文档,Vue面试题文档,大厂面试题文档