@capacitor/share
Share API 提供了在用户已安装的任意支持分享功能的应用程序中分享内容的方法。
Share API 支持 iOS、Android 和 Web(使用新的 Web Share API),不过目前 Web 端的支持尚不完善。
安装
npm install @capacitor/share@latest-5
npx cap sync
Android
默认情况下,Capacitor 应用仅允许分享缓存文件夹中的文件。若要使其他 Android 文件夹可被分享,需要将它们添加到 android/app/src/main/res/xml/file_paths.xml 文件中。请查阅 FileProvider 文档 中“指定可用文件”部分,了解可用的位置。
示例
import { Share } from '@capacitor/share';
await Share.share({
title: '看看这个很酷的东西',
text: '你绝对需要立刻看看这个超棒的东西',
url: 'http://ionicframework.com/',
dialogTitle: '分享给好友',
});
// 仅分享文本
await Share.share({
text: '你绝对需要立刻看看这个超棒的东西',
});
// 仅分享链接
await Share.share({
url: 'http://ionicframework.com/',
});
// 使用 url 参数分享本地文件
const photo = await Camera.getPhoto(options);
await Share.share({
url: photo.path,
});
// 使用 files 参数分享多个文件
const { photos } = await Camera.pickImages(options);
await Share.share({
files: photos.map(photo => photo.path!),
});
每个平台使用不同的字段集,但建议您提供所有字段。
API
canShare()
canShare() => Promise<CanShareResult>
检查当前环境是否支持分享功能。
返回值:
Promise<CanShareResult>
自版本: 1.1.0
share(...)
share(options: ShareOptions) => Promise<ShareResult>
显示分享模态框,用于将内容分享到 其他应用程序。
| 参数 | 类型 |
|---|---|
options | |
返回值:
Promise<ShareResult>
自版本: 1.0.0
接口
CanShareResult
| 属性 | 类型 | 描述 | 自版本 |
|---|---|---|---|
value | boolean | 表示当前环境是否支持分享功能。 | 1.1.0 |
ShareResult
| 属性 | 类型 | 描述 | 自版本 |
|---|---|---|---|
activityType | string | 接收分享操作的应用程序标识符。在某些情况下可能为空字符串。在 Web 端此属性为 undefined。 | 1.0.0 |
ShareOptions
| 属性 | 类型 | 描述 | 自版本 |
|---|---|---|---|
title | string | 设置分享消息的标题。在分享到电子邮件时,这将作为邮件主题。 | 1.0.0 |
text | string | 设置要分享的文本内容。 | 1.0.0 |
url | string | 设置要分享的链接,可以是 http、https 或 file:// 协议的 URL。 | 1.0.0 |
files | string[] | 要分享的文件路径数组,必须是 file:// 协议的 URL。仅在 iOS 和 Android 平台支持。 | 4.1.0 |
dialogTitle | string | 设置分享模态框的标题。此选项仅在 Android 平台支持。 | 1.0.0 |