>웹 프론트엔드 >JS 튜토리얼 >믹스인 없이 React Router에서 프로그래밍 방식으로 탐색하는 방법은 무엇입니까?

믹스인 없이 React Router에서 프로그래밍 방식으로 탐색하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-19 21:16:09821검색

How to Programmatically Navigate in React Router without Mixins?

믹스인이 없는 React Router의 프로그래밍 방식 탐색

React Router는 컨텍스트를 통한 원활한 탐색을 가능하게 하지만 사용법을 이해하는 것은 혼란스러울 수 있습니다. 믹스인을 사용하지 않고 프로그래밍 방식으로 탐색하는 방법을 살펴보겠습니다.

React Router는 컨텍스트를 통해 기록 객체를 제공하여 조작을 위한 푸시 및 교체 방법에 대한 액세스를 제공합니다. 그러나 React가 발전함에 따라 프로그래밍 방식 탐색을 위한 다양한 옵션이 제공됩니다:

1. withRouter HOC 활용(React Router 6은 지원되지 않음):

withRouter HOC는 히스토리 객체를 구성 요소 props에 주입하여 탐색 방법에 직접 액세스할 수 있도록 합니다.

import { withRouter } from 'react-router-dom';

const Button = withRouter(({ history }) => {
  const handleClick = () => { history.push('/new-location'); };
  return <button onClick={handleClick}>Click Me!</button>;
});

2. 경로 없는 경로 렌더링(React Router 6은 지원되지 않음):

경로 없이 경로 구성 요소를 렌더링합니다. 경로는 항상 현재 위치와 일치하고 기록 prop도 전달합니다.

import { Route } from 'react-router-dom';

const Button = () => {
  return (
    <Route render={({ history }) => {
      const handleClick = () => { history.push('/new-location'); };
      return <button onClick={handleClick}>Click Me!</button>;
    }} />
  );
};

3. 컨텍스트 사용(복잡하고 더 이상 사용되지 않음):

이 접근 방식은 React의 컨텍스트에 대한 깊은 이해가 필요하므로 주의해서 사용해야 합니다. 기록 속성에 액세스하려면 구성 요소 컨텍스트 유형을 정의해야 합니다.

import React from 'react';

const Button = (props, context) => {
  const handleClick = () => { context.history.push('/new-location'); };
  return <button onClick={handleClick}>Click Me!</button>;
};

Button.contextTypes = {
  history: React.PropTypes.shape({
    push: React.PropTypes.func.isRequired
  })
};

대부분의 시나리오에서 옵션 1과 2는 단순성을 제공하므로 권장됩니다.

위 내용은 믹스인 없이 React Router에서 프로그래밍 방식으로 탐색하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.