Getting Started
Kopieren Sie einen Setup-Vorschlag mit den Installationsanweisungen und der vollständigen Markdown-Anleitung für diesen Plugin.
Set up this Capacitor plugin in the project.
Use the package manager already used by the project.
Install these package(s): `@capgo/capacitor-transitions`
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/transitions/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.
Installation
Abschnitt mit dem Titel „Installation“Sie können unser AI-gestütztes Setup verwenden, um das Plugin zu installieren. Fügen Sie die Capgo-Fähigkeiten zu Ihrem AI-Tool hinzu, indem Sie folgenden Befehl ausführen:
npx skills add https://github.com/Cap-go/capgo-skills --skill capacitor-pluginsVerwenden Sie dann die folgende Anweisung:
Use the `capacitor-plugins` skill from `Cap-go/capgo-skills` to install the `@capgo/capacitor-transitions` plugin in my project.Wenn Sie die manuelle Einrichtung bevorzugen, installieren Sie das Plugin, indem Sie die folgenden Befehle ausführen und die Plattform-spezifischen Anweisungen unten befolgen:
-
Installieren Sie das Paket
Terminal-Fenster npm install @capgo/capacitor-transitions -
Registrieren Sie die Web-Komponenten
import '@capgo/capacitor-transitions'; -
Umgehen Sie die gerouteten Seiten
<cap-router-outlet platform="auto" swipe-gesture="auto"><cap-page><cap-header slot="header"><h1>Inbox</h1></cap-header><cap-content slot="content"><button>Open message</button></cap-content><cap-footer slot="footer"><nav>Tabs</nav></cap-footer></cap-page></cap-router-outlet> -
Legen Sie die Richtung fest, bevor sich Ihr Router die Route ändert
import { setDirection } from '@capgo/capacitor-transitions/react';setDirection('forward');router.push('/message/42');setDirection('back');router.back();
React-Einrichtung
Abschnitt mit dem Titel “React-Einrichtung”import { useEffect, useRef } from 'react';import { useNavigate } from 'react-router-dom';import { initTransitions, setDirection, setupPage, setupRouterOutlet } from '@capgo/capacitor-transitions/react';import '@capgo/capacitor-transitions';
initTransitions({ platform: 'auto' });
export function AppShell() { const outletRef = useRef<HTMLElement>(null);
useEffect(() => { if (!outletRef.current) return;
setupRouterOutlet(outletRef.current, { platform: 'auto', swipeGesture: 'auto', }); }, []);
return ( <cap-router-outlet ref={outletRef}> {/* Your router renders cap-page children here. */} </cap-router-outlet> );}
export function InboxPage() { const navigate = useNavigate(); const pageRef = useRef<HTMLElement>(null);
useEffect(() => { if (!pageRef.current) return;
return setupPage(pageRef.current, { onDidEnter: () => console.log('Inbox visible'), }); }, []);
return ( <cap-page ref={pageRef}> <cap-header slot="header"> <h1>Inbox</h1> </cap-header>
<cap-content slot="content"> <button onClick={() => { setDirection('forward'); navigate('/message/42'); }} > Open message </button> </cap-content> </cap-page> );}React JSX TypeScript
Abschnitt mit dem Titel “React JSX TypeScript”Importieren von @capgo/capacitor-transitions/react enthält JSX-Typen für cap-router-outlet, cap-page, cap-header, cap-content, und cap-footer. In den meisten React-Projekten macht diese Importierung die benutzerdefinierten Elemente automatisch in TSX gültig.
Wenn TypeScript immer noch meldet Property 'cap-router-outlet' does not exist on type 'JSX.IntrinsicElements', fügen Sie eine Projektdeklarationsdatei hinzu:
import '@capgo/capacitor-transitions/react';Für Vite, Create React App und die meisten webpack-React-Anwendungen ist es ausreichend, diese Datei in src/ zu platzieren. Für Next.js legen Sie sie in src/ oder den Projektroot und stellen sicher, dass tsconfig.json sie einbezieht:
{ "include": ["src", "src/capgo-transitions.d.ts"]}Für benutzerdefinierte TypeScript- oder webpack-Konfigurationen, die eine separate types/ Verzeichnis verwenden, beziehen Sie stattdessen dieses Verzeichnis ein:
{ "include": ["src", "types"]}Zurück scrollen
Abschnitt mit dem Titel “Zurück scrollen”Aktivieren oder deaktivieren Sie die iOS-Eckgeste aus Markup:
<cap-router-outlet swipe-gesture="auto"></cap-router-outlet><cap-router-outlet swipe-gesture="true"></cap-router-outlet><cap-router-outlet swipe-gesture="false"></cap-router-outlet>Oder aus JavaScript:
const outlet = document.querySelector('cap-router-outlet');
outlet?.setSwipeGesture('auto');outlet?.setSwipeGesture(true);outlet?.setSwipeGesture(false);auto Aktiviert die Geste nur, wenn Capacitor eine native iOS-Umgebung meldet. Während der Geste folgt die Seiteübergangsgeste der Fingerbewegung. Wenn der Benutzer loslässt, beendet die Übergangsgeste entweder und fragt das Browser-Historie nach, zurückzugehen, oder storniert und restauriert die aktuelle Seite.
Um ein Element davon abzuhalten, die Geste auszulösen, fügen Sie data-swipe-gesture-ignore:
<button data-swipe-gesture-ignore>Open drawer</button>Mit Native Navigation
Abschnitt mit dem Titel “Mit Native Navigation”Verwenden Sie @capgo/capacitor-transitions mit @capgo/native-navigation wenn native die oberen und unteren Leisten besitzen soll, während die Webinhalte die Ionic-Style-Seitenelemente bewegen.
-
Installieren und synchronisieren Sie das native-Navigationspaket:
Terminalfenster npm install @capgo/native-navigationnpx cap sync -
Konfigurieren Sie die native Chrome:
import { NativeNavigation } from '@capgo/native-navigation';await NativeNavigation.configure({contentInsetMode: 'css',});await NativeNavigation.setNavbar({title: 'Inbox',backButton: { visible: false },}); -
Bleiben Sie bei der Verantwortung für die Seiten nur bei der Web-Übergangsausgabe:
<cap-router-outlet platform="auto" swipe-gesture="auto"><cap-page><cap-content slot="content" fullscreen><main class="native-page">Inbox content</main></cap-content></cap-page></cap-router-outlet>.native-page {padding-top: var(--cap-native-navigation-top);padding-bottom: var(--cap-native-navigation-bottom);} -
Steueren Sie beide Systeme von denselben Router-Ereignissen aus:
import { NativeNavigation } from '@capgo/native-navigation';import { setDirection } from '@capgo/capacitor-transitions/react';import { router } from './router';await NativeNavigation.addListener('navbarBack', () => {setDirection('back');router.back();});async function openMessage(id: string) {setDirection('forward');router.push(`/message/${id}`);await NativeNavigation.setNavbar({title: 'Message',backButton: { visible: true, title: 'Inbox' },});}
Rendere die native Oberleiste nicht erneut als beweglich. Lassen Sie die Oberleiste native und verwenden Sie <cap-header> für die Unterseite des WebView-Page-Inhalts. @capgo/native-navigation Komponenten @capgo/capacitor-transitions Abschnitt mit dem Titel “Komponenten”
Abschnitt mit dem Titel “<cap-router-outlet>”
Attribut<cap-router-outlet>
Typ| Standard | Beschreibung | __CAPGO_KEEP_0__ | __CAPGO_KEEP_0__ |
|---|---|---|---|
platform | 'ios' | 'android' | 'auto' | 'auto' | Animation-Style |
duration | number | Plattform-Standard | Animation-Dauer in Millisekunden |
keep-in-dom | boolean | true | Unaktive Seiten im DOM behalten |
max-cached | number | 10 | Höchstwert der gecachten Seiten |
swipe-gesture | boolean | 'auto' | 'auto' | iOS-Randgeste aktivieren, deaktivieren oder nativ erkennen |
Methode(n):
push(element, config?)pop(config?)setRoot(element, config?)setSwipeGesture(true | false | 'auto')
<cap-page>
Abschnitt mit dem Titel “<cap-page>”Eine Seite einhüllen und Lebenszyklusereignisse ausgeben:
cap-will-entercap-did-entercap-will-leavecap-did-leave
<cap-content>
Abschnitt mit dem Titel “<cap-content>”| Attribut | Typ | Standard | Beschreibung |
|---|---|---|---|
fullscreen | boolean | false | Lassen Sie den Inhalt hinter dem Header scrollen |
scroll-x | boolean | true | Horizontalscrollen aktivieren |
scroll-y | boolean | true | Vertikalscrollen aktivieren |
Hilfe für Frameworks
Abschnitt mit dem Titel “Hilfe für Frameworks”Die Framework-Eintrittspunkte offenbaren die gleichen grundlegenden Hilfsmittel:
import { initTransitions, setDirection, setupPage, setupRouterOutlet } from '@capgo/capacitor-transitions/react';
initTransitions({ platform: 'auto' });setDirection('forward');setupRouterOutlet(element, { platform: 'auto', swipeGesture: 'auto' });setupPage(element, { onWillEnter, onDidEnter, onWillLeave, onDidLeave });Verfügbare Eintrittspunkte:
@capgo/capacitor-transitions/react@capgo/capacitor-transitions/vue@capgo/capacitor-transitions/angular@capgo/capacitor-transitions/svelte@capgo/capacitor-transitions/solid
Fortsetzung von Getting Started
Abschnitt mit dem Titel “Fortsetzung von Getting Started”Wenn Sie diese verwenden Einstieg um die Migration und die Unternehmensoperationen zu planen und zu verbinden Für die native Fähigkeit in @capgo/capacitor-Übergänge Für die native Fähigkeit in @capgo/capacitor-Übergänge, Capgo-Unternehmenslösung Für den Produktworkflow in Capgo-Unternehmenslösung Ionic-Unternehmens-Plugin-Alternativen Für den Produktworkflow in Ionic-Unternehmens-Plugin-Alternativen Capgo-Alternativen Für den Produktworkflow in Capgo-Alternativen Capgo-Beratung für das Produktworkflow in Capgo Consulting.