uniapp 智能显示导航栏 微信QQ浏览器下隐藏 H5下显示 解决微信双标题问题

文章介绍了如何使用Vue.mixin在uniapp的H5版本中处理微信和QQ浏览器显示双标题的状况。通过检测用户代理并隐藏导航栏元素,可以实现自动隐藏导航栏,达到理想的显示效果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

uniapp h5 手机版在微信里会显示双标题的问题,如下图。

效果非常不好,为了实现完美的显示效果,只需要在main.js里加入以下代码即可。

实现在微信、QQ浏览器下自动隐藏导航栏解决双标题问题,在H5手机浏览器下显示导航。


Vue.mixin({
    mounted() {
        if (this.isWeiXinBrowser() || this.isQQBrowser()) {
            this.navTitle()
        }
    },
    methods: {
        isWeiXinBrowser() {
            let ua = navigator.userAgent.toLowerCase()
            return ua.indexOf('micromessenger') != -1
        },
        isQQBrowser() {
            var ua = navigator.userAgent.toLowerCase()
            if (ua.match(/QQ/i) == "qq") {
                return true
            } else {
                return false
            }
        },
        navTitle() {
            this.$nextTick(() => {
                let navTitleDom = document.getElementsByTagName('uni-page-head')
                if (navTitleDom.length) {
                    navTitleDom[0].style.display = 'none'
                }
            })
        }
    }
})

加入代码的效果图,如下:

方法二:在文件里修改

mounted() {
	var title = document.getElementsByClassName("uni-page-head__title")[0]
	title.textContent = "我的列表"
},

Uniapp隐藏顶部导航栏有多种方法可以实现。其中一种方法是在pages.json中配置"navigationBarStyle"为"custom",并设置"navigationBarTitleText"为所需的标题。这样可以使用自定义导航栏样式来替代原生导航栏。例如: ``` { "path": "XXXX", "style": { "navigationBarTitleText": "导航栏", "navigationBarStyle": "custom" } } ``` 另一种方法是使用css来隐藏导航栏。在页面的css文件中添加以下代码: ``` /* #ifdef H5 */ uni-page-head { display: none; } /* #endif */ ``` 如果要禁用所有页面的导航栏,可以在pages.json中配置全局样式"globalStyle",将"titleNView"设置为false,例如: ``` "globalStyle": { "app-plus": { "titleNView": false } } ``` 以上就是Uniapp隐藏顶部导航栏的几种方法。您可以根据您的需求选择其中一种方法来实现。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [uniapp开发小程序H5页面顶部导航栏navigationBar如何隐藏?三种解决办法](https://blog.youkuaiyun.com/qq_37860634/article/details/131226906)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [[微信小程序] 自定义顶部导航栏(navigationBar),兼容适配所有机型(完整实例)](https://download.youkuaiyun.com/download/weixin_43951315/85459820)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [uni-app隐藏顶部导航栏](https://blog.youkuaiyun.com/qq_39998026/article/details/126422990)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值