原文地址 https://github.com/fa-ge/NativeShare/blob/master/README.md
下载地址:https://github.com/fa-ge/NativeShare
最近有一个活动页需要在移动端浏览器分享网页到微信,QQ。虽然每一个浏览器都有分享到微信的能力,但不是每个都提供接口供网页来调用。及时有提供,浏览器暴露出的api也各不相同,而我写NativeShare的目的只是为前端开发者提供一致的api来调用浏览器的原生分享组件。大小uglify + gzip = 4k。
存在的问题
demo
支持ES6模块,AMD,CMD引入 如果你的项目没有模块化。你也可以直接用script标签引入NativeShare.js。可以参考demo
import NativeShare from 'nativeshare' // 先创建一个实例 var nativeShare = new NativeShare() // 如果你需要在微信浏览器中分享,那么你需要设置额外的微信配置 // 特别提示一下微信分享有一个坑,不要分享安全域名以外的链接(具体见jssdk文档),否则会导致你配置的文案无效 // 创建实例应该带参数 var nativeShare = new NativeShare({ wechatConfig: { appId: '', timestamp: '', nonceStr: '', signature: '', }, // 让你修改的分享的文案同步到标签里,比如title文案会同步到标签中 // 这样可以让一些不支持分享的浏览器也能修改部分文案,默认都不会同步 syncDescToTag: false, syncIconToTag: false, syncTitleToTag: false, }) // 你也可以在setConfig方法中设置配置参数 nativeShare.setConfig({ wechatConfig: { appId: '', timestamp: '', nonceStr: '', signature: '', } }) // 设置分享文案 nativeShare.setShareData({ icon: 'https://pic3.zhimg.com/v2-080267af84aa0e97c66d5f12e311c3d6_xl.jpg', link: 'https://github.com/fa-ge/NativeShare', title: 'NativeShare', desc: 'NativeShare是一个整合了各大移动端浏览器调用原生分享的插件', from: '@fa-ge', }) // 唤起浏览器原生分享组件(如果在微信中不会唤起,此时call方法只会设置文案。类似setShareData) try { nativeShare.call() // 如果是分享到微信则需要 nativeShare.call('wechatFriend') // 类似的命令下面有介绍 } catch(err) { // 如果不支持,你可以在这里做降级处理 }
NativeShare一共只有五个实例方法
{ icon: '', link: '', title: '', desc: '', from: '', // 以下两个个回调目前只有在微信和百度APP中很好的支持 success: noop, fail: noop, // 只有微信支持 trigger: noop, }
调用call方法时第一个参数是指定用什么命令调用分享组件。目前支持6个命令。分别是
在支持的浏览器中点击分享时浏览器会自动调用对应的分享接口,比如点击qq好友会自动启动qq并跳到选择好友分享的页面。但微信中分享只能靠点击右上角触发,外界无法调用接口。
NativeShare demo
最后配上判断浏览器的方法,可以配合判断一下是否微信浏览器做出不同操作:
var browser={
versions:function(){
var u = navigator.userAgent, app = navigator.appVersion;
return {
trident: u.indexOf('Trident') > -1, //IE内核
presto: u.indexOf('Presto') > -1, //opera内核
webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1,//火狐内核
mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
android: u.indexOf('Android') > -1 || u.indexOf('Adr') > -1, //android终端
iPhone: u.indexOf('iPhone') > -1 , //是否为iPhone或者QQHD浏览器
iPad: u.indexOf('iPad') > -1, //是否iPad
webApp: u.indexOf('Safari') == -1, //是否web应该程序,没有头部与底部
weixin: u.indexOf('MicroMessenger') > -1, //是否微信 (2015-01-22新增)
qq: u.match(/\sQQ/i) == " qq" //是否QQ
};
}(),
language:(navigator.browserLanguage || navigator.language).toLowerCase()
}
//判断是否IE内核
if(browser.versions.trident){ alert("is IE"); }
//判断是否webKit内核
if(browser.versions.webKit){ alert("is webKit"); }
//判断是否移动端
if(browser.versions.mobile||browser.versions.android||browser.versions.ios){ alert("移动端"); }
//检测浏览器语言
currentLang = navigator.language; //判断除IE外其他浏览器使用语言
if(!currentLang){//判断IE浏览器使用语言
currentLang = navigator.browserLanguage;
}
alert(currentLang);