微信公众平台开发:进阶篇(微信内置浏览器关注微信好友实践)

  
  
  
  
  1. //通过关注微信好友   
  2.     
  3. function WeiXinAddContact(wxid)   
  4. {   
  5.     if (typeof WeixinJSBridge == 'undefined'return false;   
  6.         WeixinJSBridge.invoke('addContact', {   
  7.             webtype: '1',   
  8.             username: wxid   
  9.         }, function(d) {   
  10.             // 返回d.err_msg取值,d还有一个属性是err_desc   
  11.             // add_contact:cancel 用户取消   
  12.             // add_contact:fail 关注失败   
  13.             // add_contact:ok 关注成功   
  14.             // add_contact:added 已经关注   
  15.            // WeixinJSBridge.log(d.err_msg);   
  16.                
  17.         });   
  18. };   
  19. //通过微信分享   
  20. function WeiXinShareBtn() {   
  21.    if (typeof WeixinJSBridge == "undefined") {   
  22.         alert("请先通过微信xxxx");   
  23.     } else {   
  24.         WeixinJSBridge.invoke('shareTimeline', {   
  25.             "title""xxx",   
  26.             "link""http://www.xxx.com",   
  27.             "desc""关注xxx",   
  28.             "img_url""http://www.xxx.com/xxx.png"   
  29.         });   
  30.     }   
  31. }   
  1. 上面的代码目前在微信内置浏览器才有效果
  2. WeiXinAddContact中的微信wxid需要 微信的原始id,为什么呢?
    例如美食行的微信id:meishixing,原始id:gh_6cc3b345c2f2,
    在iphone版本的微信中使用两种id都能完成正常的关注,但是在android版本的微信meishixing这个无法返回一直停留在“正在关注。。。”,修改成id:gh_6cc3b345c2f2,就正常了。这个问题找来好久。。。
  3. 如果用户希望用户在打开页面的时候,直接能弹出关注的对话框
  
  
  
  
  1. //init   
  2. function r(f){(typeof WeixinJSBridge == 'undefined'||(typeof WeixinJSBridge.invoke == 'undefined'))?setTimeout('r('+f+')',200):f()}   
  3. r(function(){   
  4.    WeiXinAddContact("gh_6cc3b345c2f2");   
  5. });  

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

你可能感兴趣的:(微信平台开发指南)