微信内置浏览器关注微信好友实践

/通过关注微信好友
 
function WeiXinAddContact(wxid)
{
    if (typeof WeixinJSBridge == 'undefined') return false;
        WeixinJSBridge.invoke('addContact', {
            webtype: '1',
            username: wxid
        }, function(d) {
            // 返回d.err_msg取值,d还有一个属性是err_desc
            // add_contact:cancel 用户取消
            // add_contact:fail 关注失败
            // add_contact:ok 关注成功
            // add_contact:added 已经关注
           // WeixinJSBridge.log(d.err_msg);
            
        });
};
//通过微信分享
function WeiXinShareBtn() {
   if (typeof WeixinJSBridge == "undefined") {
        alert("请先通过微信xxxx");
    } else {
        WeixinJSBridge.invoke('shareTimeline', {
            "title": "xxx",
            "link": "http://www.xxx.com",
            "desc": "关注xxx",
            "img_url": "http://www.xxx.com/xxx.png"
        });
    }
}

  1. 上面的代码目前在微信内置浏览器才有效果
  2. WeiXinAddContact中的微信wxid需要 微信的原始id,为什么呢?
    例如美食行的微信id:meishixing,原始id:gh_6cc3b345c2f2,
    在iphone版本的微信中使用两种id都能完成正常的关注,但是在android版本的微信meishixing这个无法返回一直停留在“正在关注。。。”,修改成id:gh_6cc3b345c2f2,就正常了。这个问题找来好久。。。
  3. 如果用户希望用户在打开页面的时候,直接能弹出关注的对话框
//init
function r(f){(typeof WeixinJSBridge == 'undefined'||(typeof WeixinJSBridge.invoke == 'undefined'))?setTimeout('r('+f+')',200):f()}
r(function(){
   WeiXinAddContact("gh_6cc3b345c2f2");
});  

微信内置浏览器会有WeixinJSBridge,但是需要一定的加载时间,WeixinJSBridge 有了之后 WeixinJSBridge.invoke也不一定有,所有看到r这个函数了把。。。(ps:每次打开都弹多不好意思阿,所以需要通过cookie来控制,WeiXinAddContact回调状态来设置cookie和通过cookie判断是否要执行init的部分的r)

你可能感兴趣的:(微信内置浏览器关注微信好友实践)