直接上圖,金山的APP“微信導航”,從界面上看有粉絲數等關鍵數據,實現了直接關注功能,莫不是rest接口?這江湖是大佬們的江湖,小嘍啰只有眼饞的份咯。
很早就聽說過WeixinJSBridge,不過官方貌似不提倡,先曬曬學習筆記
【Pockey】編輯整理
- //通過關注微信好友
- function WeiXinAddContact(wxid, cb)
- {
- 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);
- cb && cb(d.err_msg);
- });
- };
- //通過微信分享
- function WeiXinShareBtn() {
- if (typeof WeixinJSBridge == "undefined") {
- alert("請先通過微信xxxx");
- } else {
- WeixinJSBridge.invoke('shareTimeline', {
- "title": "xxx",
- "link": "xxxx",
- "desc": "關注xxx",
- "img_url": "xxxx"
- });
- }
- }
1. 上面的代碼目前在微信內置瀏覽器才有效果
2. WeiXinAddContact中的微信wxid需要微信的原始id
例如商翼雲的微信id:i3eyun,原始id:gh_b15f77615e32,
在iphone版本的微信中使用兩種id都能完成正常的關注
但在android版本中如果使用i3eyun這個無法返回,一直停留在“正在關注。。。”,而修改成id:gh_b15f77615e32就正常了
3. 如果用戶希望用戶在打開頁面的時候,直接能彈出關注的對話框
- //init
- function r(f){(typeof WeixinJSBridge == 'undefined'||(typeof WeixinJSBridge.invoke == 'undefined'))?setTimeout('r('+f+')',200):f()}
- r(function(){
- WeiXinAddContact("gh_b15f77615e32");
- });
微 信內置瀏覽器會有WeixinJSBridge,但是需要一定的加載時間,WeixinJSBridge 有了之后 WeixinJSBridge.invoke也不一定有,所有看到r這個函數了把。。。(ps:每次打開都彈多不好意思阿,所以需要通過cookie來控 制,WeiXinAddContact回調狀態來設置cookie和通過cookie判斷是否要執行init的部分的r)
【Denis】分享
- //分享到朋友圈
- function weixinShareTimeline(title,desc,link,imgUrl){
- WeixinJSBridge.invoke('shareTimeline',{
- "img_url":imgUrl,
- //"img_width":"640",
- //"img_height":"640",
- "link":link,
- "desc": desc,
- "title":title
- });
- }
- //發送給好友
- function weixinSendAppMessage(title,desc,link,imgUrl){
- WeixinJSBridge.invoke('sendAppMessage',{
- //"appid":appId,
- "img_url":imgUrl,
- //"img_width":"640",
- //"img_height":"640",
- "link":link,
- "desc":desc,
- "title":title
- });
- }
- //分享到騰訊微博
- function weixinShareWeibo(title,link){
- WeixinJSBridge.invoke('shareWeibo',{
- "content":title + link,
- "url":link
- });
- }
- //關注指定的微信號
- function weixinAddContact(name){
- WeixinJSBridge.invoke("addContact", {webtype: "1",username: name}, function(e) {
- WeixinJSBridge.log(e.err_msg);
- //e.err_msg:add_contact:added 已經添加
- //e.err_msg:add_contact:cancel 取消添加
- //e.err_msg:add_contact:ok 添加成功
- if(e.err_msg == 'add_contact:added' || e.err_msg == 'add_contact:ok'){
- //關注成功,或者已經關注過
- }
- })
- }
【jodan179】分享
1. 在微信內置瀏覽器中可以調用weixin協議鏈接直接查看某個微信號的資料,例如:
- <a href="weixin://profile/gh_b15f77615e32">商翼雲</a>
這里gh_xxxxxxxx就是用戶的原始ID,注意,必須使用原始ID.
2. 分享到朋友圈:
- function ShareTofriends(img_url,link,title,desc) {
- //在HTML頁面內嵌入這一段JS代碼
- if(window.WeixinJSBridge){
- if( typeof(img_url) == 'undefined' || img_url == ""){
- var img_url = "xxxx";
- }
- if( typeof(link) == 'undefined' || link == ""){
- var img_url = window.location.href;
- }
- if ( typeof(title) == 'undefined' || title == "" ){
- var title = '點開看一下吧!';
- }
- if( typeof(desc) == 'undefined' || desc == ""){
- var desc = "wendoscoo";
- }
- WeixinJSBridge.invoke('shareTimeline',{
- "img_url": img_url,
- //"img_width": "640",
- //"img_height": "640",
- "link": link,
- "desc": desc,
- "title": title
- },function(res){
- // 返回res.err_msg,取值
- // share_timeline:cancel 用戶取消
- // share_timeline:fail 發送失敗
- // share_timeline:ok 發送成功
- WeixinJSBridge.log(res.err_msg);
- });
- return false;
- } else{
- alert("WeixinJSBridge對象不存在!!");
- }
- };
然后同樣使用一個a標簽實現分享功能,加上onclick時間調用分享的JS函數就可以了
- <a href="javascript:void(0);" onclick="ShareTOfriend('分享彈出窗的圖片URL地址','分享的頁面鏈接','分享彈出窗的標題','分享內容的描述')">分享到朋友圈</a>
相關功能尚未測試,后續情況將記錄在我的下一篇學習筆記中,敬請期待