欢迎来到素材无忧网,按 + 收藏我们
登录 注册 退出 找回密码

浏览器唤起qq进行聊天的一些坑和解决方案

时间: 2020-09-15 09:36 阅读: 作者:素材无忧网

针对跳转唤起QQ,QQ推广的官方网站http://shang.qq.com/v3/index....,只需要扫描登录需要被唤起的QQ号,就可以生成一段代码如下所示:

<a target="_blank" href="http://wpa.qq.com/msgrd?v=3&uin=123456789&site=qq&menu=yes">
<img border="0" src="http://wpa.qq.com/pa?p=2:123456789:52" alt="点击这里给我发消息" title="点击这里给我发消息"/>
</a>

这里的数字“123456789”就是需要被唤起的QQ号码。

应用这种方式,可以在大部分的浏览器中唤起QQ客户端,并定位到聊天页面,只是以下几种情况中这种方式会失效:

  1. 苹果手机自带的 Safari 浏览器会提示是否在AppStore中打开链接,如果选择是就会直接跳转到App Store 中,然后才能跳转到QQ,但是两次跳转会丢失参数,导致不能打开需要聊天的对象。
  2. 在手机端Google浏览器中也会存在类似于 1 中的情况
  3. 网页内嵌到自开发的App中,需要唤起QQ时也会出现类似与 1 的情况。

由于Safari浏览器在苹果手机端使用率很高,应业务需求,就不得不为它找一种另外的方式。

单独说倒唤起QQ,或者解决Safari浏览器不能唤起QQ的问题,可以使用如下的URI:

mqqwpa://im/chat?chat_type=wpa&uin=123456789&version=1&src_type=web&web_src=freshtime.cn

其中数字“123456789”同样的是需要被唤起的QQ。

<a target="_blank" href="mqqwpa://im/chat?chat_type=wpa&uin=123456789&version=1&src_type=web&web_src=freshtime.cn">
 123456789
</a>

通过多次测试,我整理出如下手机端浏览器唤起QQ的各种不同情况(其中no代表测试不成功,ok代表测试成功):

浏览器唤起qq进行聊天的一些坑和解决方案(图1)

这里需要提到一点,将URL Scheme 的方案用于电脑的各种浏览器从而去唤起QQ是不起任何效果,因为URL Scheme是专门为解决APP之间孤立的情况而提出来的,并不适用于电脑应用,但是在电脑端可以使用QQ推广给出的的方案。

知道了如何解决App跳转到QQ的方法,但是很多时候我们希望有一种通用的办法可以解决上述几种情况,保证在大多数浏览器(包括电脑浏览器)只需要一套代码就可以解决问题。

我个人通过判断浏览器的userAgent区分手机端浏览器还是电脑端浏览器,然后为它们分别提供不同的方案:

HTML代码

<a?href="javascript:void(0)"?data-qq='qq'>111111111111</a>

JavaScript代码

window.onload = function () {
    var as = document.getElementsByTagName('a');
    var kefu101 = "http://wpa.qq.com/msgrd?v=3&uin=381232999&site=freshtime.cn&menu=yes";
    var kefu102 = "mqqwpa://im/chat?chat_type=wpa&uin=381232999&version=1&src_type=web&web_src=freshtime.cn";

    for (var i = 0, len = a.length; i < len; i++) {
        if (as[i].hasAttribute('data-qq')) {
            as[i].onclick = (function (i) {
                return function (e) {
                    var kefu = e.target ? e.target.getAttribute('data-qq') : e.srcElement.getAttribute('data-qq');
                    if (/(iPhone|iPad|iPod|iOS)/i.test(navigator.userAgent) || /(Android)/i.test(navigator.userAgent)) {
                        window.open(kefu102);
                    }
                   else {window.open(kefu101);}
                }
            })(i);
        }
    }
};

这套方案中,手机端使用URL Scheme,电脑端使用QQ推广的方案。

版权声明: 本站资源均来自互联网或会员发布,如果侵犯了您的权益请与我们联系,我们将在24小时内删除!谢谢!

转载请注明: 浏览器唤起qq进行聊天的一些坑和解决方案

相关文章
模板推荐