开始入门
复制一个包含安装步骤和本插件的完整 Markdown 指南的配置提示。
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-nfc`
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/nfc/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.
Install
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-nfc` plugin in my project.如果您prefer Manual Setup,安装插件并运行以下命令并遵循以下平台特定的说明:
bun add @capgo/capacitor-nfcbunx cap syncimport { CapacitorNfc } from '@capgo/capacitor-nfc';API概述
标题为“API概述”startScanning
标题为“startScanning”开始监听NFC标签。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.startScanning();stopScanning
标题为“stopScanning”停止当前的NFC扫描会话。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.stopScanning();write
标题为“write”将提供的NDEF记录写入最后发现的标签。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.write({} as WriteTagOptions);erase
Section titled “清除”尝试通过写入空 NDEF 消息来清除最后发现的标签。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.erase();makeReadOnly
Section titled “使只读”尝试将最后发现的标签设置为只读。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.makeReadOnly();share
Section titled “分享”通过对等 (仅 Android) 共享 NDEF 消息。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.share({} as ShareTagOptions);unshare
Section titled “停止分享”停止共享之前提供的 NDEF 消息 (仅 Android)。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.unshare();getStatus
getStatus获取当前NFC适配器状态。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.getStatus();showSettings
显示设置打开系统设置页面,用户可以在此处启用NFC。
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.showSettings();isSupported
isSupported检查设备是否支持NFC硬件。
返回 true 如果设备上有NFC硬件,无论NFC是否当前启用或禁用,均返回true。 false 如果设备上没有NFC硬件,返回false。
使用此方法来确定是否在应用程序UI中显示NFC功能。要检查NFC是否当前启用,请使用 getStatus().
import { CapacitorNfc } from '@capgo/capacitor-nfc';
await CapacitorNfc.isSupported();类型参考
类型参考StartScanningOptions
开始扫描选项控制 . 的行为
export interface StartScanningOptions { /** * iOS-only: closes the NFC session automatically after the first successful tag read. * Defaults to `true`. */ invalidateAfterFirstRead?: boolean; /** * iOS-only: custom message displayed in the NFC system sheet while scanning. */ alertMessage?: string; /** * iOS-only: session type to use for NFC scanning. * - `'ndef'`: Uses NFCNDEFReaderSession (default). Only detects NDEF-formatted tags. * - `'tag'`: Uses NFCTagReaderSession. Detects both NDEF and non-NDEF tags (e.g., raw MIFARE tags). * Allows reading UID from unformatted tags. * **Requires** the `Near Field Communication Tag Reader Session Formats` entitlement * in your app with the `TAG` format included. Without it the session will fail to * start and the promise will reject with a `NO_NFC` error code. * Defaults to `'ndef'` for backward compatibility. */ iosSessionType?: 'ndef' | 'tag'; /** * Android-only: raw flags passed to `NfcAdapter.enableReaderMode`. * Defaults to enabling all tag types with skipping NDEF checks. */ androidReaderModeFlags?: number;}WriteTagOptions
写标签选项用于在当前标签上写入 NDEF 消息的选项
export interface WriteTagOptions { /** * Array of records that compose the NDEF message to be written. */ records: NdefRecord[]; /** * When `true`, the plugin attempts to format NDEF-formattable tags before writing. * Defaults to `true`. */ allowFormat?: boolean;}ShareTagOptions
共享标签选项用于使用 Android Beam / P2P 模式共享 NDEF 消息的选项
export interface ShareTagOptions { records: NdefRecord[];}NfcStatus
Nfc状态NFC适配器可能的状态
export type NfcStatus = 'NFC_OK' | 'NO_NFC' | 'NFC_DISABLED' | 'NDEF_PUSH_DISABLED';NfcEvent
Nfc事件NFC插件派发的通用NFC发现事件
export interface NfcEvent { type: NfcEventType; tag: NfcTag;}NfcStateChangeEvent
Nfc状态改变事件NFC适配器可用性改变时派发的事件
export interface NfcStateChangeEvent { status: NfcStatus; enabled: boolean;}NdefRecord
NDEF记录JSON结构表示单个NDEF记录
export interface NdefRecord { /** * Type Name Format identifier. */ tnf: number; /** * Type field expressed as an array of byte values. */ type: number[]; /** * Record identifier expressed as an array of byte values. */ id: number[]; /** * Raw payload expressed as an array of byte values. */ payload: number[];}NfcEventType
NfcEventType描述 NFC 发现事件的类型。
export type NfcEventType = 'tag' | 'ndef' | 'ndef-mime' | 'ndef-formatable';NfcTag
NfcTag表示本地层返回的完整标签信息。
export interface NfcTag { /** * Raw identifier bytes for the tag. */ id?: number[]; /** * List of Android tech strings (e.g. `android.nfc.tech.Ndef`). */ techTypes?: string[]; /** * Human readable tag type when available (e.g. `NFC Forum Type 2`, `MIFARE Ultralight`). */ type?: string | null; /** * Maximum writable size in bytes for tags that expose NDEF information. */ maxSize?: number | null; /** * Indicates whether the tag can be written to. */ isWritable?: boolean | null; /** * Indicates whether the tag can be permanently locked. */ canMakeReadOnly?: boolean | null; /** * Array of NDEF records discovered on the tag. */ ndefMessage?: NdefRecord[] | null;}真实来源
此页面由插件生成。当公共 __CAPGO_KEEP_0__ 在上游发生变化时,请重新同步。 src/definitions.ts. Re-run the sync when the public API changes upstream.
从 Getting Started 继续
此页面由插件生成,内容可能会随时更新。如果您正在使用 开始使用 来规划仪表板和API操作,连接它与 使用@capgo/capacitor-nfc 为本机能力在使用@capgo/capacitor-nfc, API概述 为实现细节在API概述, 介绍 为实现细节在介绍, API密钥 为实现细节在API密钥,和 设备 为设备的实现细节。