本文介绍: 注:在手机小程序上使用uni.previewImage预览图片时会调用onHide、onShow,在关闭图片的几秒时间内操作卡顿。注:目前小程序拦截返回,只检测到了在某种状态下返回的行为,但没有理想的事件执行。当在图片预览状态左滑返回时,不返回上一页面,而是关闭图片预览状态。1、区分电脑小程序和手机小程序。3、app左滑、导航键返回拦截。
1、区分电脑小程序和手机小程序
//区分电脑小程序、手机小程序(目标:手机小程序)
// #ifdef MP-WEIXIN
uni.getSystemInfo({
success: (res) => {
// windows | mac为pc端
// android | ios为手机端
// console.log('getSystemInfo,', res.platform);
if (res.platform == "android" || res.platform == "ios")
this.preMode = true;
}
});
// #endif
2、小程序拦截返回
注:目前小程序拦截返回,只检测到了在某种状态下返回的行为,但没有理想的事件执行
//小程序左滑、导航键返回拦截
onLoad(){
//小程序拦截左滑,导航键返回
if (!this.$fn.empty(this.previewFlag)) {
wx.enableAlertBeforeUnload({
message: "点击右上角关闭"
});
}
}
method:{
// 查看文件
open(event) {
this.previewFlag = true;
if (this.preMode) {
// #ifdef MP-WEIXIN
wx.enableAlertBeforeUnload({
message: "点击右上角关闭",
});
// #endif
}
},
close() {
this.previewFlag = false;
if (this.preMode) {
// #ifdef MP-WEIXIN
wx.disableAlertBeforeUnload();
// #endif
}
},
}
3、app左滑、导航键返回拦截
当在图片预览状态左滑返回时,不返回上一页面,而是关闭图片预览状态
// 拦截图片预览返回上一页面
onBackPress(e) {
if (e.from == "navigateBack" || e.from == "backbutton") {
if (!this.$fn.empty(this.previewFlag)) {
this.$refs.fileopen.close();
return true;
}
}
},
注:在手机小程序上使用uni.previewImage预览图片时会调用onHide、onShow,在关闭图片的几秒时间内操作卡顿
原文地址:https://blog.csdn.net/fanxingxue/article/details/135995497
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.7code.cn/show_65285.html
如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱:suwngjj01@126.com进行投诉反馈,一经查实,立即删除!
声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。