Кнопка ссылки для перехода к другому компоненту не работает в React js

avatar
Kishan Kumar
8 августа 2021 в 21:51
200
1
2

Я реализую форму и загружаю введенный текст из формы в формате PDF. Но я столкнулся с проблемой при реализации кнопки «Далее» и «Отправить», которая может перенаправить на мой компонент PDF, у которого есть возможность загрузить форму. Может ли кто-нибудь помочь мне здесь, чтобы решить эту проблему :) Ниже приведен мой компонент с именем «Карта» с кнопкой «Далее», который должен перейти к компоненту PDF:

enter code here

import React , { Component} from 'react';
import Button from '@material-ui/core/Button';
import CssBaseline from '@material-ui/core/CssBaseline';
import TextField from '@material-ui/core/TextField';
import FormControlLabel from '@material-ui/core/FormControlLabel';
import Checkbox from '@material-ui/core/Checkbox';
import Link from '@material-ui/core/Link';
import Grid from '@material-ui/core/Grid';
import Typography from '@material-ui/core/Typography';
import { withStyles } from '@material-ui/core/styles';
import Container from '@material-ui/core/Container';
import PDF from './PDF';

const useStyles = (theme) => ({
  paper: {
    marginTop: "theme.spacing(8)",
    display: 'flex',
    flexDirection: 'column',
    alignItems: 'center',
  },
  avatar: {
    margin: 'spacing(1)',
    backgroundColor: 'palette.secondary.main',
    alignItems:'center'
  },
  form: {
    width: '100%', // Fix IE 11 issue.
    marginTop: 'spacing(3)',
  },
  submit: {
    margin: 'spacing(3, 0, 2)'
  },
});




class Map extends React.Component {
   
    userData;

    constructor (props)  {
        super(props);
        this.onChangefirstName = this.onChangefirstName.bind(this);
        this.onChangelastName = this.onChangelastName.bind(this);
        this.onChangeEmail = this.onChangeEmail.bind(this);
        this.onChangePhone = this.onChangePhone.bind(this);
        this.onSubmit = this.onSubmit.bind(this);
        
        this.state = {
            fname: '',
            lname:'',
            email: '',
            phone: '',
            postSubmitted:false
        }
        
    }
    
    // Form event
    onChangefirstName(e) {
        this.setState({ fname: e.target.value})
    }

    onChangelastName(e){
        this.setState({lname: e.target.value})
    }

    onChangeEmail(e){
        this.setState({email: e.target.value})
    }

    onChangePhone(e){
        this.setState({phone: e.target.value})
    }

    onSubmit(e){
        e.preventDefault()

    }

    //React Lifecycle

    componentDidMount(){
        this.userData = JSON.parse(localStorage.getItem('user'));
        if (localStorage.getItem('user')) {
            this.setState({
                fname: this.userData.fname,
                lname: this.userData.lname,
                email: this.userData.email,
                phone: this.userData.phone
            })
            
        } else {
            this.setState({
                fname: '',
                lname: '',
                email: '',
                phone: ''
            })
            
        }
    }

    componentWillUpdate(nextProps, nextState){
        localStorage.setItem('user', JSON.stringify(nextState));
    }

    //Validation
    submitPost = e => {
        if (!this.state.fname || !this.state.lname || !this.state.email) {
            alert(" All fields are required")
            e.preventDefault();
        } else {
            this.setState({
                postSubmitted: true
            });
        }
    }
    render(){

      const {classes} = this.props;
             
        return (

            <>
                { 
                    <Container component="main" maxWidth="xs">
                    <CssBaseline />
                    <div className={classes.paper}><br></br>
                    
                        <Typography component="h1" variant="h5">
                        Tell About Yourself
                        </Typography> <br></br>
                        <form className={classes.form} onSubmit={this.onSubmit}>
                        <Grid container spacing={2}>
                            <Grid item xs={12} sm={6}>
                            <TextField
                                autoComplete="fname"
                                name="firstName"
                                variant="outlined"
                                required
                                fullWidth
                                id="firstName"
                                label="First Name"
                                autoFocus
                                value={this.state.fname}
                                onChange={this.onChangefirstName}

                            />
                            </Grid>
                            <Grid item xs={12} sm={6}>
                            <TextField
                                variant="outlined"
                                required
                                fullWidth
                                id="lastName"
                                label="Last Name"
                                name="lastName"
                                autoComplete="lname"
                                value={this.state.lname}
                                onChange={this.onChangelastName}

                            />
                            </Grid>
                            <Grid item xs={12}>
                                <TextField
                                variant="outlined"
                                required
                                fullWidth
                                id="email"
                                label="Email Address"
                                name="email"
                                value={this.state.email}
                                onChange={this.onChangeEmail}
                                />
                            </Grid>
                            <Grid item xs={12}>
                            <TextField
                                variant="outlined"
                                required
                                fullWidth
                                name="phone"
                                label="Phone Number"
                                type="phone"
                                id="phone"
                                autoComplete="phone"
                                value={this.state.phone}
                                onChange={this.onChangePhone}
                            />
                            </Grid>
                            <Grid item xs={12}>
                            <FormControlLabel
                                control={<Checkbox value="allowExtraEmails" color="primary" /> }
                                label="Your contact details will be shared with TØyen Unlimited"
                                alignItems='row'
                            />
                            </Grid>
                        </Grid><br></br>
                        <Button
                            fullWidth
                            variant="contained"
                            color="secondary"
                            className={classes.submit}
                            
                            component={Link}
                            to="/PDF"
                        >
                            Submit and Go to next
                        </Button>
                        
                        </form>
                    </div>
                    </Container> 
                }
            </>
        );
     }
}

export default withStyles(useStyles, {withTheme:true}) (Map)

Вот мой компонент App.js, в котором я определил свойство Route:

import './App.css';
import {  makeStyles} from '@material-ui/core/styles'
import { BrowserRouter as Router, Route } from "react-router-dom";
import NavBar from './Components/NavBar';
import Home from './Components/Home';
import About from './Components/About';
import Map from './Components/Map';
import Footer from './Components/Footer';
import PDF from './Components/PDF';


const styles = makeStyles({
  wrapper: {
    width: "65%",
    margin: "auto" ,
    textAlign: "center",
  },
 
  bigSpace: {
    marginTop:  "5rem"
  },
  littleSpace:  {
    marginTop:  "2.5rem"
  },
  title: {
    color: "#314976",
    font: "Italic"
  }
})


function App() {
  const classes = styles();

  return (
    <Router>
      <div className="App">
        <NavBar/>

        <div className={classes.wrapper}>
          <switch>
            <Route exact path="/">
              <Home/>
            </Route>
            <Route exact path="/About">
              <About/>
            </Route>
            <Route exact path="/Map">
              <Map/>
            </Route>
            <Route exact path="/PDF" >
              <PDF/>
            </Route>
            
          </switch>
        </div>
      
        <div  className={classes.bigSpace}>
          <Footer/>
        </div>

      </div>
    </Router>

          

  );  
}

export default App;
Источник

Ответы (1)

avatar
Drew Reese
8 августа 2021 в 23:32
1

Я думаю, что проблема здесь в том, что вы импортируете и используете компонент Link из Material-UI, а не компонент <5941203200391> из <5941203200514>

>
import Link from '@material-ui/core/Link';

Ссылка на интерфейс материала

Из того, что я могу сказать по компоненту Material-UI Link, отображается обычный тег привязки, то есть для ссылки на внешние ресурсы, а не на маршруты внутри приложения. Другими словами, ссылка не использует контекст маршрутизации для обработки какой-либо навигации.

Я считаю, что самое простое решение — просто импортировать компонент react-router-dom Link.

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

...

<Button
  fullWidth
  variant="contained"
  color="secondary"
  className={classes.submit}
  component={Link}
  to="/PDF"
>
  Submit and Go to next
</Button>

Edit link-button-to-route-to-the-another-component-is-not-working-in-react-js

Kishan Kumar
9 августа 2021 в 06:08
0

Спасибо за указание, и теперь он работает нормально после импорта Link из react-router-dom.

Drew Reese
9 августа 2021 в 06:09
0

@KishanKumar Добро пожаловать. Мне пришлось сначала протестировать его, чтобы подтвердить, поэтому я включил для вас код песочницы. :) Ваше здоровье.

Kishan Kumar
21 сентября 2021 в 16:00
0

Но есть проблема с этим BrowserRouter, потому что, когда я обновляюсь и нажимаю кнопку «Назад» в браузере, страница становится пустой :( У вас есть какие-либо комментарии по этому поводу?

Drew Reese
21 сентября 2021 в 16:22
0

@KishanKumar Привет, это звучит как новая и другая проблема, было бы лучше опубликовать новый вопрос на SO и включить соответствующий код и конкретные детали проблемы. Вы можете пинговать (2) меня здесь со ссылкой на вопрос или в комментарии к вашему новому сообщению, и я могу взглянуть. Мне нужно больше подробностей о том, что означает «страница становится пустой», и я хотел бы увидеть ваш текущий код.