Richtlinie
Tutorial zu Übergängen
Mit @capgo/capacitor-Übergängen
@capgo/capacitor-transitions Fügt Ionic-Style Routenübergänge zu Capacitor-Anwendungen hinzu, ohne Ionic UI zu übernehmen. Es läuft im Weblayer, hält Ihre bestehende Router und kann ein iOS-Rückgabetasten-Gestisch nur innerhalb von native Capacitor iOS automatisch aktivieren.
Installieren
npm install @capgo/capacitor-transitions
Es gibt keine native Synchronisationsstufe, weil das Paket keine native Plugin code hinzufügt.
Registrieren Sie die Elemente
import '@capgo/capacitor-transitions';
Wrap Ihre 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>
Verbinden Sie es mit einem Router
Legen Sie die Übergangsdirektion vor Ihrer normalen Routenaktualisierung fest:
import { setDirection } from '@capgo/capacitor-transitions/react';
setDirection('forward');
router.push('/message/42');
setDirection('back');
router.back();
Reaktionsbeispiel
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}>{/* routes */}</cap-router-outlet>;
}
export function InboxPage() {
const navigate = useNavigate();
const pageRef = useRef<HTMLElement>(null);
useEffect(() => {
if (!pageRef.current) return;
return setupPage(pageRef.current);
}, []);
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>
);
}
Die React-Unterpfad enthält JSX-Typen für die benutzerdefinierten Elemente. Wenn TypeScript immer noch meldet, dass cap-router-outlet existiert nicht auf JSX.IntrinsicElements, fügen Sie diese Datei hinzu:
// src/capgo-transitions.d.ts
import '@capgo/capacitor-transitions/react';
Für Vite, Create React App und die meisten webpack-React-Anwendungen reicht es aus, diese Datei unter src/ zu behalten. Bei Next.js oder benutzerdefinierten TypeScript-Einstellungen stellen Sie sicher, dass sie durch tsconfig.json:
{
"include": ["src", "src/capgo-transitions.d.ts"]
}
eingeschlossen ist.
Aktivieren Sie die Rückblendeingabe swipe-gesture="auto" to enable the gesture only when Capacitor reports a native iOS runtime:
<cap-router-outlet swipe-gesture="auto"></cap-router-outlet>
um die Geste nur dann zu aktivieren, wenn __CAPGO_KEEP_0__ eine native iOS- Runtime meldet:
const outlet = document.querySelector('cap-router-outlet');
outlet?.setSwipeGesture(true);
outlet?.setSwipeGesture(false);
outlet?.setSwipeGesture('auto');
Sie können sie auch aus JavaScript zwingen: data-swipe-gesture-ignore Die Geste folgt dem Finger während der Übergabe, dann abschließt oder storniert sie, wenn der Benutzer loslässt. Fügen Sie
auf Schaltflächen, Sliders oder Schubladen hinzu, die die Edge-Geste nicht auslösen sollen. Verwenden Sie sie mit nativer Navigation
Install @capgo/native-navigation wenn die native Layer die Navbar oder Tabbar besitzen soll:
npm install @capgo/native-navigation
npx cap sync
Konfigurieren Sie das native Chrome, dann behalten Sie die Übergänge auf den WebView-Seiten im Fokus:
import { NativeNavigation } from '@capgo/native-navigation';
import { setDirection } from '@capgo/capacitor-transitions/react';
import { router } from './router';
await NativeNavigation.configure({
contentInsetMode: 'css',
});
await NativeNavigation.setNavbar({
title: 'Inbox',
backButton: { visible: false },
});
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' },
});
}
Use cap-content für die animierte Seite und native-Navigation-CSS-Variablen für Einfügungen:
<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);
}
Duplicieren Sie die native Navbar nicht als bewegliche Web-Überschrift. @capgo/native-navigation hält die Bar native; @capgo/capacitor-transitions animiert die Seite unter ihr.
Full Reference
- GitHub: https://github.com/Cap-go/capacitor-Übergänge/
- Dokumentation: /docs/plugins/Übergänge/
Bleiben Sie bei der Verwendung von @capgo/capacitor-Übergänge
Wenn Sie die Verwendung von Mit @capgo/capacitor-Übergänge um native Medien und Schnittstellenverhalten zu planen, verbinden Sie es mit @capgo/capacitor-Übergänge für die Implementierungsdetails in @capgo/capacitor-Übergänge, Einstieg für die Implementierungsdetails in Einstieg, Mit @capgo/capacitor-live-Aktivitäten für die native Fähigkeit in Mit @capgo/capacitor-live-Aktivitäten, @capgo/capacitor-live-Aktivitäten für die Implementierungsdetails in @capgo/capacitor-live-Aktivitäten und Mit @capgo/capacitor-Video-Player für die native Fähigkeit in Mit @capgo/capacitor-Video-Player.