컨텐츠로 바로가기

시작하기

GitHub
  1. 패키지를 설치하세요.

    터미널 창
    npm install @capgo/capacitor-transitions
  2. 웹 컴포넌트를 등록하세요.

    import '@capgo/capacitor-transitions';
  3. 라우팅된 페이지를.wrap하세요.

    <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>
  4. __CAPGO_KEEP_0__에서 경로가 변경되기 전에 방향을 설정하세요.

    import { setDirection } from '@capgo/capacitor-transitions/react';
    setDirection('forward');
    router.push('/message/42');
    setDirection('back');
    router.back();

React 설정

React 설정
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>
);
}

JSX 형식의 타입을 포함하여 가져오기. @capgo/capacitor-transitions/react JSX 형식의 타입을 포함하여 가져오기. cap-router-outlet, cap-page, cap-header, cap-content, 그리고 cap-footer. 대부분의 React 프로젝트에서, 그 import는 TSX에서 사용할 수 있는 커스텀 엘리먼트를 자동으로 유효하게 만듭니다.

TypeScript가 여전히 Property 'cap-router-outlet' does not exist on type 'JSX.IntrinsicElements', 프로젝트 선언 파일을 추가하세요:

src/capgo-transitions.d.ts
import '@capgo/capacitor-transitions/react';

Vite, Create React App, 및 대부분의 webpack React 앱의 경우, 그 파일을 src/ 에 넣으면 됩니다. Next.js의 경우, src/ 또는 프로젝트 루트에 넣고 tsconfig.json 를 포함하도록 하세요:

{
"include": ["src", "src/capgo-transitions.d.ts"]
}

커스텀 TypeScript 또는 webpack 설정을 사용하는 경우, 별도의 types/ 폴더, 그 폴더를 포함하세요:

{
"include": ["src", "types"]
}

마크업에서 iOS 에지 제스처를 활성화/비활성화 하세요:

<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>

또는 자바스크립트에서:

const outlet = document.querySelector('cap-router-outlet');
outlet?.setSwipeGesture('auto');
outlet?.setSwipeGesture(true);
outlet?.setSwipeGesture(false);

auto Capacitor이 네이티브 iOS 런타임을 보고 있을 때만 제스처를 활성화합니다. 제스처 중 페이지 전환은 손가락에 따라 진행됩니다. 사용자가 손가락을 놓으면 전환은 완료되고 브라우저 히스토리에게 뒤로 가기를 요청하거나 취소되고 현재 페이지를 복원합니다.

제스처를 시작하지 않도록 하려면 data-swipe-gesture-ignore:

<button data-swipe-gesture-ignore>Open drawer</button>

Use @capgo/capacitor-transitions with @capgo/native-navigation native가 상단 및 하단 바를 소유하고 Ionic-style 페이지 동작을 유지하는 경우 사용하세요.

  1. Install and sync the native navigation package:

    native 네비게이션 패키지를 설치하고 동기화하세요:
    npm install @capgo/native-navigation
    npx cap sync
  2. Configure native chrome:

    import { NativeNavigation } from '@capgo/native-navigation';
    await NativeNavigation.configure({
    contentInsetMode: 'css',
    });
    await NativeNavigation.setNavbar({
    title: 'Inbox',
    backButton: { visible: false },
    });
  3. Keep the web transition outlet responsible for pages only:

    <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);
    }
  4. __CAPGO_KEEP_0__ 이벤트:

    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' },
    });
    }

원래 네이티브 탑바를 다시 렌더링하지 마세요. <cap-header>. Let @capgo/native-navigation 네이티브 바를 유지하고 @capgo/capacitor-transitions WebView 페이지 콘텐츠 아래에 사용하세요.

속성타입기본값설명
platform'ios' | 'android' | 'auto''auto'애니메이션 스타일
durationnumber플랫폼 기본밀리초 단위 애니메이션 지속 시간
keep-in-dombooleantrue비활성 페이지를 DOM에 유지
max-cachednumber10캐시된 페이지의 최대 수
swipe-gestureboolean | 'auto''auto'iOS 에지 제스처를 iOS 기본, 비활성화 또는 네이티브 감지로 활성화/비활성화

메서드:

  • push(element, config?)
  • pop(config?)
  • setRoot(element, config?)
  • setSwipeGesture(true | false | 'auto')

페이지 하나를.wrap하고 라이프 사이클 이벤트를 전송:

  • cap-will-enter
  • cap-did-enter
  • cap-will-leave
  • cap-did-leave
속성타입기본설명
fullscreenbooleanfalse헤더 뒤에 콘텐츠가 스크롤 될 수 있도록 해주세요
scroll-xbooleantrue가로 스크롤을 활성화하세요
scroll-ybooleantrue세로 스크롤을 활성화하세요

프레임워크 엔트리 포인트는 동일한 핵심 헬퍼를 노출합니다.

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 });

사용 가능한 엔트리 포인트:

  • @capgo/capacitor-transitions/react
  • @capgo/capacitor-transitions/vue
  • @capgo/capacitor-transitions/angular
  • @capgo/capacitor-transitions/svelte
  • @capgo/capacitor-transitions/solid

Getting Started에서 계속 진행하세요

Getting Started에서 계속하기

__CAPGO_KEEP_0__이 사용 중인 경우 Getting Started __CAPGO_KEEP_0__과 연결하여 capgo/capacitor-transitions을 사용하여 capgo/capacitor-transitions의 Native 기능을 사용하여 Capgo Enterprise Capgo Enterprise의 제품 워크플로우를 사용하여 Ionic Enterprise Plugin Alternatives __CAPGO_KEEP_0__ Alternatives Capgo Alternatives의 제품 워크플로우를 사용하여 Capgo Alternatives Capgo Consulting Capgo Consulting 제품 워크플로우를 위한