原生分享首选 Web Share API(navigator.share),需 HTTPS 和用户手势触发,支持 title/text/url;微信必须用 JS-SDK 配合后端签名;Twitter/Facebook/LinkedIn 可用 URL Scheme;og 标签仅影响链接预览,不控制分享行为。
现代浏览器已支持 navigator.share(),无需第三方 SDK,不依赖网络请求,用户点击即调用系统级分享面板。这是最轻量、最隐私友好的方案。
http://localhost 也允许)click)中触发,不能 onload 自动调用title、text、url,但不支持图片(files 参数目前仅 Android Chrome 支持)try...catch,因为 iOS Safari 旧版本或 Firefox 仍不支持document.getElementById('share-btn').addEventListener('click', async () => {
if (navigator.share) {
try {
await navigator.share({
title: '网页标题',
text: '分享文案',
url: window.location.href
});
} catch (err) {
console.log('分享被取消或不支持:', err);
}
} else {
// 降级:显示自定义按钮或跳转到分享链接
fallbackShare();
}
});
微信浏览器禁用 navigator.share(),且所有自定义分享(朋友圈/好友)必须通过 wechat-js-sdk + 后端签名,静态页无法绕过。
access_token 和 jsapi_ticket 对当前 URL 签名,返回 signature、nonceStr、timestamp
appId 和假签名——微信会静默失败,控制台无报错,只看到“配置失败”这些平台仍开放简单 URL Scheme 分享,无需注册 App 或引入 SDK,适合纯静态页。注意参数编码和平台限制:
Twitter:用 https://twitter.com/intent/tweet?url=...,支持 text、hashtags,但不支持 via(已废弃)Facebook:用 https://www.facebook.com/sharer/sharer.php?u=...,仅接受 u 参数,其他如 quote 不生效LinkedIn:用 https://www.linkedin.com/sharing/share-offsite/?url=...,必须带协议头,否则 400encodeURIComponent,尤其是中文和特殊符号encodeURIComponent(window.location.href)&text=encodeURIComponent('分享文案')" target="_blank">推特分享
很多教程说加 就能让微信或微博抓取,这是误解。
og: 标签只对「链接被粘贴到聊天框时」的预览生效,不影响点击分享按钮的行为og:,坚持用自己缓存的标题(除非调用 JS-SDK 设置 updateAppMessageShareData)og:,但必须部署在公网可访问域名下,本地 file:// 或未备案域名会被屏蔽og:image 但图片路径是相对路径或跨域资源,会导致预览图空白——务必用绝对 HTTPS 路径