在微信里,其实可以改变“分享到朋友圈”和“转发给好友”的默认行为。这些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, {});
分享到:
相关推荐
微信浏览器内置了javascript私有对象WeixinJSBridge,可以实现发送给朋友、分享到朋友圈、分享到微博等功能,本篇文章给大家介绍基于js实现微信发送给朋友如何分享到朋友圈、微博,感兴趣的朋友一起学习吧
主要介绍了微信浏览器内置JavaScript对象WeixinJSBridge使用实例,本文给出了分享到朋友圈、发送给好友、分享到腾讯微博、关注指定的微信号等功能代码,需要的朋友可以参考下
而“微信分享朋友圈”作为微信平台的一项核心功能,允许用户将自己感兴趣的信息、文章、图片等内容分享至微信朋友圈,从而达到信息的快速扩散和社交互动的目的。本文将深入探讨微信分享朋友圈的实现原理,包括如何...
微信WeixinJSBridge API续_Alien的笔记.mht 微信内置JsAPI之WeixinJSBridge_Alien的笔记.mht 微信内置浏览器的JsAPI(WeixinJSBridge续)_Alien的笔记.mht
本文实例讲述了JS实现微信里判断页面是否被分享成功的方法。分享给大家供大家参考,具体如下: var shareData = { img_url: , img_width: 200, ... // 发送给好友 WeixinJSBridge.on('menu:share:appmessage',
主要介绍了微信内置浏览器私有接口WeixinJSBridge介绍,本文讲解了发送给好友、分享函数、隐藏工具栏、隐藏三个点按钮等功能,需要的朋友可以参考下
通过`WeixinJSBridge.on`方法,开发者可以监听微信客户端的特定事件,例如`scanCode`(扫描二维码)或`onMenuShareTimeline`(分享到朋友圈)。当这些事件发生时,对应的回调函数会被执行。 6. **微信支付...
微信WeixinJSBridge使用及结果判断
本文档提供的代码就是一种实现方式,它通过检测用户是否使用微信浏览器访问网页,并进一步利用微信浏览器提供的API来关闭转发功能。 #### 1.1 用户Agent识别 首先,代码通过分析用户代理(User-Agent)来判断当前...
1. 微信分享功能的概述:在Web页面中嵌入微信分享功能,能够让用户通过微信将自己的页面内容分享给微信好友或者分享到朋友圈和微博。这样可以增加内容的传播力度和范围,提高用户的互动体验。 2. 实现微信分享的...
1、分享到微信朋友圈 2、分享给微信好友 3、分享到腾讯微博 4、隐藏/显示右上角的菜单入口 5、隐藏/显示底部浏览器工具栏 6、获取当前的网络状态 7、调起微信客户端的图片播放组件 8、关闭公众平台Web页面 /**! *...
分享提示:点击右上角,选择“发送给朋友”或“分享到朋友圈” 关闭" id="popover-close"> ``` 这里的`class="hidden"`和`id="popover-close"`是用于CSS样式控制和JavaScript交互的。 接下来,CSS用于美化和...
主要介绍了微信WeixinJSBridge API使用实例,本文直接给出HTML代码,代码中包含了很多实用功能,如图片预览、分享到微博、隐藏右上角按钮、获取网络状态、发起公众号微信支付等内容,需要的朋友可以参考下
总的来说,微信小程序提供了强大的API来控制分享行为。开发者可以根据需求选择隐藏分享菜单、隐藏底部工具栏,或者自定义分享内容。通过理解并熟练运用这些API,我们可以为用户提供更加符合产品定位的分享体验。在...
在示例代码中,`WeixinJSBridge`对象包含了调用接口的方法,如`invoke('sendAppMessage')`、`invoke('shareTimeline')`和`invoke('shareWeibo')`分别对应分享到好友、朋友圈和微博。在`WeixinJSBridgeReady`事件触发...