开始
__CAPGO_KEEP_4__
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-file-picker`
Run the required Capacitor sync/update step after installation.
Read this markdown guide for the full setup steps: https://raw.githubusercontent.com/Cap-go/website/refs/heads/main/apps/docs/src/content/docs/docs/plugins/file-picker/getting-started.mdx
Use that guide for platform-specific steps, native file edits, permissions, config changes, imports, and usage setup.
If that guide references other docs pages, read them too.
__CAPGO_KEEP_11__
Section titled “Install”您可以使用我们的AI辅助安装程序来安装插件。使用以下命令将Capgo技能添加到您的AI工具中:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-plugins然后使用以下提示:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-file-picker` plugin in my project.如果您更喜欢手动安装,请运行以下命令并按照以下平台特定的说明进行操作:
bun add @capgo/capacitor-file-pickerbunx cap syncimport { CapgoFilePicker } from '@capgo/capacitor-file-picker';API 介绍
API 介绍标题pickFiles
__CAPGO_KEEP_0__ 选取文件从设备中选择一个或多个文件。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.pickFiles({ types: ['application/pdf', 'image/*'], limit: 5, readData: false});console.log('Picked files:', result.files);pickImages
__CAPGO_KEEP_0__ 选取图片从相册中选择一个或多个图片。 仅限 Android/iOS。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.pickImages({ limit: 10, readData: false});console.log('Picked images:', result.files);pickVideos
__CAPGO_KEEP_0__ 选取视频从相册中选择一个或多个视频。 仅限 Android/iOS。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.pickVideos({ limit: 3, skipTranscoding: true});console.log('Picked videos:', result.files);pickMedia
__CAPGO_KEEP_0__ 选取媒体从相册中选择一个或多个图片或视频。 仅限Android/iOS。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.pickMedia({ limit: 5, readData: true});console.log('Picked media:', result.files);pickDirectory
“pickDirectory”标题从设备中选择一个目录。 仅限Android/iOS。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.pickDirectory();console.log('Selected directory:', result.path);convertHeicToJpeg
“convertHeicToJpeg”标题将HEIC图片转换为JPEG格式。 仅限iOS。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const result = await CapgoFilePicker.convertHeicToJpeg({ path: '/path/to/image.heic', quality: 0.9});console.log('Converted file:', result.path);copyFile
“copyFile”标题将文件复制到新位置。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
await CapgoFilePicker.copyFile({ from: '/source/file.pdf', to: '/destination/file.pdf', overwrite: true});checkPermissions
“checkPermissions”标题检查读取文件的权限。 仅限 Android。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const status = await CapgoFilePicker.checkPermissions();console.log('Read permission:', status.readExternalStorage);requestPermissions
名为“requestPermissions”的部分为读取文件请求权限。 仅限 Android。
import { CapgoFilePicker } from '@capgo/capacitor-file-picker';
const status = await CapgoFilePicker.requestPermissions();if (status.readExternalStorage === 'granted') { console.log('Permission granted');}PickFilesOptions
名为“PickFilesOptions”的部分选择文件的选项。
export interface PickFilesOptions { /** * List of accepted MIME types or file extensions. * On iOS, only MIME types are supported. * Examples: ['image/*'], ['application/pdf'], ['.pdf', '.doc'] */ types?: string[]; /** * Maximum number of files to pick. * Set to 0 for unlimited (platform default). * @default 0 */ limit?: number; /** * Whether to read the file data as base64. * Note: Reading large files may cause memory issues. * @default false */ readData?: boolean;}PickFilesResult
名为“PickFilesResult”的部分选择文件的结果。
export interface PickFilesResult { /** Array of picked files */ files: PickedFile[];}PickMediaOptions
标题:“PickMediaOptions”选择媒体(图片/视频)的选项。
export interface PickMediaOptions { /** * Maximum number of files to pick. * Set to 0 for unlimited (platform default). * @default 0 */ limit?: number; /** * Whether to read the file data as base64. * Note: Reading large files may cause memory issues. * @default false */ readData?: boolean; /** * iOS only: Skip transcoding of videos. * @default false */ skipTranscoding?: boolean; /** * iOS 15+ only: Show ordered selection badges. * @default false */ ordered?: boolean;}PickDirectoryResult
标题:“PickDirectoryResult”选择目录的结果。
export interface PickDirectoryResult { /** The path to the selected directory */ path: string;}ConvertHeicToJpegOptions
标题:“ConvertHeicToJpegOptions”HEIC转JPEG的选项。
export interface ConvertHeicToJpegOptions { /** The path to the HEIC file to convert */ path: string; /** * The compression quality for JPEG (0.0 - 1.0). * @default 0.9 */ quality?: number;}ConvertHeicToJpegResult
标题:“ConvertHeicToJpegResult”HEIC转JPEG的结果。
export interface ConvertHeicToJpegResult { /** The path to the converted JPEG file */ path: string;}CopyFileOptions
CopyFileOptions标题复制文件的选项。
export interface CopyFileOptions { /** Source file path */ from: string; /** Destination file path */ to: string; /** * Whether to overwrite if destination exists. * @default false */ overwrite?: boolean;}PermissionStatus
PermissionStatus标题文件访问权限状态。
export interface PermissionStatus { /** Whether permission to read media files is granted */ readExternalStorage: PermissionState; /** Whether permission to access media location is granted */ accessMediaLocation?: PermissionState;}PickerDismissedListener
PickerDismissedListener标题选择器关闭事件回调。
export type PickerDismissedListener = (event: null) => void;PickedFile
PickedFile标题选中的文件。
export interface PickedFile { /** The name of the file */ name: string; /** The path to the file */ path?: string; /** The MIME type of the file */ mimeType: string; /** The size of the file in bytes */ size: number; /** * The base64 encoded data of the file. * Only present if readData was true. */ data?: string; /** * The Blob instance of the file. * Web only. */ blob?: Blob; /** Width in pixels (images/videos only) */ width?: number; /** Height in pixels (images/videos only) */ height?: number; /** Duration in seconds (videos only) */ duration?: number; /** Last modified timestamp in milliseconds */ modifiedAt?: number;}PermissionState
标题:权限状态权限状态值
export type PermissionState = 'prompt' | 'prompt-with-rationale' | 'granted' | 'denied';真实来源
标题:真实来源本页面是根据插件生成的。 src/definitions.ts当公共 API 在上游发生变化时,请重新运行同步。
从开始就继续
标题:从开始就继续如果您正在使用 开始 为了规划存储和文件处理,连接它与 使用 @capgo/capacitor-file-picker 对于 @capgo/capacitor-file-picker 的本机能力, @capgo/capacitor-data-storage-sqlite 对于 @capgo/capacitor-data-storage-sqlite 的实现细节, 使用 @capgo/capacitor-data-storage-sqlite 对于使用 @capgo/capacitor-data-storage-sqlite 的本机能力, @capgo/capacitor-file 对于 @capgo/capacitor-file 的实现细节, 使用 @capgo/capacitor-file 对于使用 @capgo/capacitor-file 的本机能力,