资讯专栏INFORMATION COLUMN

nativeShare 移动端浏览器调用原生分享插件

tomorrowwu / 2696人阅读

摘要:原文地址起因最近有一个活动页需要在移动端浏览器分享网页到微信,。及时有提供,浏览器暴露出的也各不相同,而我写的目的只是为前端开发者提供一致的来调用浏览器的原生分享组件。

原文地址 https://github.com/fa-ge/NativeShare/blob/master/README.md

起因

最近有一个活动页需要在移动端浏览器分享网页到微信,QQ。虽然每一个浏览器都有分享到微信的能力,但不是每个都提供接口供网页来调用。及时有提供,浏览器暴露出的api也各不相同,而我写NativeShare的目的只是为前端开发者提供一致的api来调用浏览器的原生分享组件。大小uglify + gzip = 4k。

兼容性(毫无疑问是兼容浏览器最多的插件了)

移动端几乎所有浏览器都支持分享到QQ和QQ空间

QQ浏览器

UC浏览器

微信自带浏览器(只能设置文案,分享需要用户手动点击右上角)

ios QQ自带浏览器(只能设置文案,分享需要用户手动点击右上角)

QQ空间APP(只能设置文案,分享需要用户手动点击右上角)

android百度浏览器

支持分享到web微博

即将支持(安卓QQ自带浏览器)

存在的问题

虽然几乎所有的浏览器都支持分享到QQ和QQ空间,但是webview中基本都会不支持。我也很难判断当前浏览器是否支持,浏览器是否唤起QQ APP我也很难判断,所有除了上述支持的浏览器,APP外其他情况调用分享到QQ我也会抛出异常。

安卓的QQ自带浏览器分享有问题

UC浏览器安卓端不能设置icon

百度浏览器安卓端不能指定分享

示例

demo

使用

支持ES6模块,AMD,CMD引入
如果你的项目没有模块化。你也可以直接用script标签引入NativeShare.js。可以参考demo

import NativeShare from "nativeshare"

// 先创建一个实例
var nativeShare = new NativeShare()
// 如果你需要在微信浏览器中分享,那么你需要设置额外的微信配置
// 特别提示一下微信分享有一个坑,不要分享安全域名以外的链接(具体见jssdk文档),否则会导致你配置的文案无效
// 创建实例应该带参数
var nativeShare = new NativeShare({
  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) {
  // 如果不支持,你可以在这里做降级处理
}
API

NativeShare一共只有三个实例方法

getShareData() 获得分享的文案

setShareData() 设置分享的文案

call(command = "default", [options]) 调用浏览器原生的分享组件

{
    icon: "",
    link: "",
    title: "",
    desc: "",
    from: "",
    // 以下几个回调目前只有在微信中支持和QQ中支持
    success: noop,
    fail: noop,
    cancel: noop,
    trigger: noop,
}

调用call方法时第一个参数是指定用什么命令调用分享组件。目前支持6个命令。分别是

default 默认,调用起底部的分享组件,当其他命令不支持的时候也会调用该命令

wechatTimeline 分享到朋友圈

wechatFriend 分享给微信好友

qqFriend 分享给QQ好友

qZone 分享到QQ空间

weibo 分享到微博

交流

如果你是浏览器开发者或者你知道其他浏览器调用分享的方式,请务必一定要告诉我。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/87032.html

相关文章

  • 页面实现分享

    摘要:首先,有自己的配置,可以直接调起右上角的自带分享,,转成微信或手百小程序都可用。其次,如果页面内想通过按钮调用分享功能的话,的组件可以将,这个值转为微信小程序和手百小程序都适用。 最近在做小程序项目,选用的京东的taro框架,一套代码可编译多个环境,不需要一个环境写一套代码,用着还不错。现在分享已经成为一个日常操作,下面就来简单说下我最近调研的分享功能。 首先,taro有自己的配置,可...

    littlelightss 评论0 收藏0
  • 从前开发者看待用友建筑云移动单点登录与报错原因

    摘要:本文对单点登录有一个初步介绍,重点叙述前端开发者使用单点登录可能遇到的问题,以及问题分析方案全部来源于用友建筑云,本文仅用于内部分享,所以不过多介绍方案实现。 本文对单点登录有一个初步介绍,重点叙述前端开发者使用单点登录可能遇到的问题,以及问题分析!方案全部来源于用友建筑云,本文仅用于内部分享,所以不过多介绍方案实现。原文来自博客 单点登录介绍 showImg(https://seg...

    Youngdze 评论0 收藏0
  • 在做移动开发的时候,一些应该知道的知识

    摘要:起因一天在群里面朋友问了一个这么一个问题看了之后自己梳理了一遍,在此和大家分享一下,这个就要从客户端开发的过程来讲了原生开发在移动互联网刚兴起的时候,最初的开发模式是通过或开发原生应用,有一些网页跳转的处理,使用之后增加了,安卓使用的是这个 起因 一天在群里面朋友问了一个这么一个问题: showImg(https://segmentfault.com/img/bVbiopb); 看了之...

    Hegel_Gu 评论0 收藏0

发表评论

0条评论

tomorrowwu

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<