@lamborjiny
Я нуждающийся в помощи начинающий программист)

Как по нажатию на кнопку перейти на другую страницу в React?

Здравствуйте! Помогите пожалуйста!
Дело в том, что я пытаюсь по нажатию на кнопку перейти на совершенно новую страницу моего проекта в React. Потом, на той другой странице есть кнопка 'Назад' которая перекидывает обратно. Ниже одна из моих попыток реализовать первый шаг (В адресной строке, при клике на кнопу, отражается ссылка, но страница не появляется). Если есть идеи что я не так делаю, пожалуйста поделитесь)
import React from "react";
import ReactDOM from "react-dom";
import Statistics from "../Statistics_components/Statistics.js";

 class Statistics_button extends React.Component {
    onclick () {
      window.location.assign('../Statistics_components/Statistics.js');
    }

    render() {
      return (<button onClick={(e) => this.onclick(e)}><i className="fas fa-chart-bar"></i></button>);
    }
  }
export default Statistics_button;
  • Вопрос задан
  • 37953 просмотра
Решения вопроса 1
@lamborjiny Автор вопроса
Я нуждающийся в помощи начинающий программист)
Друзья, наконец то прояснение наступило. Ниже пример реализации:

Импортируйте в основной компонент App свои страницы, у этом случае это FirstPageComponent и SecondPageComponent
import React, { Component } from "react";
import FirstPageComponent from "./FirstPageComponent.js";
import SecondPageComponent from"./SecondPageComponent";
import { BrowserRouter as Router, Route, Link } from "react-router-dom";

Дальше делайте привязку этих страниц в App с помощью react-router следующим образом
function App (){
  return(
    <Router>
      <div className="App">
        <Route path="/" exact exact component={FirstPageComponent}
        }/>
        <Route path="/second" exact component={SecondPageComponent}/>
     </div>
     </Router>
  )
}
export default App;


Дальше, желательно в отдельных файлах сделать привязку к соответствующим кнопкам на ваших страницах следующим образом
import React from "react";
import ReactDOM from "react-dom";

 class OnSecondPageButton extends React.Component {
    onclick () {
      window.location.assign('http://localhost:3000/second/');
    }

    render() {
      return (<a onClick={(e) => this.onclick(e)}><i className="fas fa-chart-bar"></i></a>);
    }
  }
export default Statistics_button;

import React from "react";
import ReactDOM from "react-dom";

 class Back_button extends React.Component {
    onclick () {
      window.location.assign('http://localhost:3000/');
    }

    render() {
      return (<button  onClick={(e) => this.onclick(e)}>Back </button>);
    }
  }
export default Back_button;


Потом не забываем импортировать свои кнопочки и вызвать в нужных местах Ваших страничек.

Как то так. Спасибо за поддержку. Успехов Вам)
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
Robur
@Robur
Знаю больше чем это необходимо
вы не можете перейти на js- файл.
как это делать правильно - посмотрите https://reacttraining.com/react-router/
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
23 нояб. 2024, в 01:31
1000 руб./за проект
23 нояб. 2024, в 00:16
2000 руб./за проект