解决iOS12以上微信内置浏览器下键盘收起底部空白的问题

原文链接:https://www.jianshu.com/p/a57946771c4d

/*
 * iOS12以上版本,微信打开链接点击输入框获取焦点后虚拟键盘自动弹出
 * 收起键盘,原来弹出键盘的位置一片空白,页面没有自动适应整个屏幕
 * 解决办法:
 * 在当前页面滚动的位置上下滚动1px的距离即可实现页面的自适应
 */
 document.body.addEventListener('focusout', () => {
     //软键盘收起的事件处理
    let ua = window.navigator.userAgent;
    let app = window.navigator.appVersion;
    //$alert('浏览器版本: ' + app + '\n' + '用户代理: ' + ua);
    if(!!ua.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/)) {
        //$alert('ios端');
	var currentPosition, timer;
	var speed = 1;
	timer = setInterval(function() {
	    currentPosition = document.documentElement.scrollTop || document.body.scrollTop;
	    currentPosition -= speed;
	    window.scrollTo(0, currentPosition); //页面向上滚动
	    currentPosition += speed;
	    window.scrollTo(0, currentPosition); //页面向下滚动
	    clearInterval(timer);
	}, 100);
    } else if(ua.indexOf('Android') > -1 || ua.indexOf('Adr') > -1) {
        //$alert('android端');
    }
 })

 

<think>好的,用户的问题是关于如何修改微信内置浏览器的设置或者切换默认浏览器。首先,我需要确认微信内置浏览器本身是否允许用户自行修改设置或切换默认浏览器。根据已有的知识,微信内置浏览器是基于腾讯的X5内核,普通用户通常无法直接修改其核心设置,比如默认浏览器切换。 接下来,用户可能的需求是什么?用户可能希望在微信中点击链接时,自动跳转到手机的其他浏览器,比如Chrome或Safari,以便下载应用或访问某些被微信限制的页面。根据引用内容,微信会拦截下载链接,导致无法直接下载,这时候需要跳转到外部浏览器。 现在需要整理现有的解决方案。引用3提到了使用Mindjump的API接口生成跳转链接,这种方法可以绕过微信的限制,让用户自动跳转到默认浏览器。另外,引用5也提到了类似的技术方案,可能涉及中间页面的处理,比如通过用户点击按钮触发跳转,或者服务器端检测User-Agent来引导用户。 需要注意的是,微信官方并不鼓励绕过其内置浏览器的行为,所以这些方法可能有一定的风险,比如链接被微信封禁。此外,iOS和Android的处理方式不同,iOS可能需要引导用户通过Safari打开,而Android可以直接跳转到默认浏览器。 用户的问题中还提到修改微信内置浏览器的设置,但根据现有信息,用户无法直接修改微信内置浏览器设置。因此,回答需要明确说明这一点,并重点提供间接方法,比如生成跳转链接或使用中间页面。 最后,需要验证这些方法的可行性和最新情况,因为微信的政策和技术可能会变化。确保提供的解决方案是目前有效的,比如Mindjump的API是否仍然可用,或者是否有其他替代服务。</think>### 如何实现微信内置浏览器跳转默认浏览器微信内置浏览器默认无法直接修改其核心设置或切换默认浏览器,但可通过以下方法间接实现跳转需求: --- #### **1. 通过中间跳转链接(推荐)** 利用第三方服务生成跳转链接,绕过微信拦截: - **操作步骤**: 1. 使用工具如[Mindjump](http://www.mindjump.cn)生成跳转链接[^3]。 2. 将生成的链接或二维码分享至微信。 3. 用户点击后,系统自动判断设备类型: - **iOS**:直接打开App Store或跳转Safari下载。 - **Android**:自动启动默认浏览器访问目标页面[^3]。 --- #### **2. 技术方案(需开发能力)** 通过检测浏览器标识(User-Agent)实现跳转: - **代码示例(PHP/JavaScript)**: ```javascript // 判断是否为微信内置浏览器 function isWeixinBrowser() { const ua = navigator.userAgent.toLowerCase(); return ua.indexOf('micromessenger') !== -1; } // 若是微信环境,提示用户用浏览器打开 if (isWeixinBrowser()) { window.location.href = "https://跳转中间页地址"; // 替换为中间页URL } ``` **中间页逻辑**: - 显示提示信息(如“点击右上角用浏览器打开”)[^5]。 - 或通过页面重定向引导外部浏览器访问[^2]。 --- #### **3. 平台差异处理** - **iOS系统**: - 企业签名包可直接在微信内下载。 - App Store链接需通过跳转中间页触发[^1]。 - **Android系统**: - 直接跳转默认浏览器访问目标页面。 --- #### **注意事项** - 微信可能更新拦截策略,需定期测试跳转功能。 - 避免使用敏感关键词(如“下载”)降低被封风险。 - 用户需手动授权地理位置等权限[^4]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值