前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >uniapp app端 webview 返回多次

uniapp app端 webview 返回多次

作者头像
风花一世月
发布2024-03-19 14:04:39
760
发布2024-03-19 14:04:39
举报
文章被收录于专栏:前端前端

嵌入页面有多个历史时,app端默认会返回嵌入页面的上一页,而不是uniapp的上一页

onBackPress可以拦截到返回类型,实体返回(from = backbutton)、导航栏左上角返回(from = backbutton)、uni.navigateBack()返回 (from = navigateBack)

onBackPress返回为true才不执行默认返回、使用自己的方法

注:onBackPress里调用uni.navigateBack()并返回为true时,会死循环,需要判断from = navigateBack时返回false

代码语言:javascript
复制
onBackPress(e) {

    if (e.from === 'navigateBack') {  
        return false;  
    }  
                
    let pages = getCurrentPages()  
    let page = pages[pages.length - 1];  
    let currentPages = page.$getAppWebview()  //获得当前webview的对象
    let children=currentPages.children()  
    
    
    if(children.length===0){  
        uni.navigateBack()  
    }else{  
        children[0].close()  
        setTimeout(()=>{  
            uni.navigateBack()  
        },80)  
    }
    
    return true;
},
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2023-01-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档