利用WeixinJSBridge,控制分享到朋友圈和转发给好友的行为
在微信里,其实可以改变“分享到朋友圈”和“转发给好友”的默认行为。这些js接口,截止到今天(安卓版微信6.0)还是不公开的,微信的官方文档里完全没有提到,但是其实借助WeixinJSBridge是可以做到的
分享行为
可以控制以下几种行为
缩略图
默认是微信自动截取当前页面中第一张大图,也就是<img>标签,而且width要超过一定的值。display:none和background-image是不算的,只能是<img>标签
但是通过传递参数,可以自己指定一张图片
分享页面
默认分享的是当前页面,通过定制,可以指定一个URL,点击后会跳转到此URL
标题
分享文本的标题,只对“转发给好友”有效,“分享到朋友圈”不显示标题。默认会取当前页面的<head> -> <title>的内容,可以设置成任意文本
内容
分享文本的内容。在“转发给好友”时,默认是当前页面的URL。在“分享到朋友圈”时,默认是<head> -> <title>的内容,可以设置成任意文本
左下角的小签名
在朋友圈看不到(但是从APP里调用SDK分享到朋友圈,可以显示),“转发给好友”可以在左下角看到。这个行为比较复杂,如果转发的是一个图文消息,就是链接是mp.weixin.qq.com/s?__biz=xxxx这种的,左下角默认会带公众号的名字,但是不会有图片;否则的话,不会有签名。然后可以设置一个app_id,那么就都会显示签名。有趣的是,这里的app_id可以任意填,只要你能知道。而且如果填的是公众号的app_id,就不会有图片,图片的位置是一个白色小方块;如果填的是腾讯开放平台的app_id,就会带上一个图片
回调行为
分享到朋友圈,和转发给好友之后,其实在页面里都会得到js回调,而且是不同的回调,比如开始转发,取消转发,转发成功,每个阶段都会有回调函数。这个小秘密有时候非常有用,因为开发者就可以控制转发之后的行为。但是微信本身的态度是不鼓励引导分享,强制分享的,所以这些接口一直没有公开,而且或许有一天突然就被封了也说不定。毕竟不是没有先例,曾经连关注公众号都是有JS API了,现在早就不能用了
另外,android版的微信有BUG,只要用户点了转发到朋友圈,回调就会立刻被调用,不管之后用户是否真的分享,应该是android版微信的BUG,这个版本至今也没有修复。iOS版的微信没有这个BUG,所有回调都可以正确执行
lib
可以直接通过WeixinJSBridge实现本文说的功能,但是显然有更好的办法,用WeixinAPI这个第三方库,可以更容易地实现这些功能,在github上就可以找到,以下是最简单的示例代码,详细的文档见主页说明
var wxData = { "title": "标题写在这里", "link": "www.baidu.com", "appId": "your app_id", "desc": "the desc" }; var wxCallbacks = { confirm: function(resp) { // 当用户点击分享到朋友圈,就会触发此回调 } }; Api.shareToTimeline(wxData, wxCallbacks); Api.shareToFriend(wxData, {});
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。