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

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

Linda Hamilton
풀어 주다: 2024-12-19 21:16:09
원래의
843명이 탐색했습니다.

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿