• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

React zdarzenie po kliknięciu

Object Storage Arubacloud
0 głosów
337 wizyt
pytanie zadane 4 października 2019 w JavaScript przez michal_php Stary wyjadacz (13,700 p.)

Cześć.

Uczę się Reacta.I mam małą zagadkę.Otóż jak mogę stworzyć zdarzenie aby po kliknięciu podstawić inny komponent:

Zrobiłem już coś takiego:

import React from 'react';
import 'bootstrap/dist/css/bootstrap.min.css';
import Home__binding from "./binding/Home__binding";

class Home extends React.Component{
    constructor(props){
        super();
        this.state = {value:null};
    }

    render() {
        return(
            <div className="container">
                <h1>Home !</h1>
                <button className="btn btn-success btn-sm" onClick={() => <Home__binding title="title" content="content"/> }>
                    Binding
                </button>
            </div>
        );
    }
}
export default Home;

 

1 odpowiedź

0 głosów
odpowiedź 4 października 2019 przez Paweł Nąckiewicz Nałogowiec (48,990 p.)
komentarz 4 października 2019 przez michal_php Stary wyjadacz (13,700 p.)

Coś nie kumam nie rozumie po co jest to question w pliku App.js ?

mam tak zbudowany kod na podstawie tego tutoriala , lecz nie widzie mi question nie za bardzo kumam o co z nim chodzi 

import React from 'react';
import 'bootstrap/dist/css/bootstrap.min.css';
import Home__binding from "./binding/Home__binding";
import HomeList from "./binding/Home__List";

class Home extends React.Component{
    constructor(props){
        super();
        this.state = {value:null};
    }
    state ={
        question:[
            {id:1 , title: 'autor nieznany' , description:'Dzieło autora' , dateTime:'20-03-1931' }
        ],displayQuestion: false
    }

    displayQuestion =() => {
        this.setState({
            displayQuestion: !this.state.displayQuestion
        })
    }

    render() {
        if ( this.state.displayQuestions ) {
            questions = (
                <div>
                   {this.state.question.map((question,index)=>{
                       return <HomeList key={question.id} title={question.title} description={question.description} dateTime={question.dateTime} />
                   })}
                </div>
            )
        }
        return(
            <div className="container">
                <h1>Home !</h1>
                <button className="btn btn-success btn-sm" onClick={this.displayQuestion}>
                    Binding
                </button>
                {questions}
               {/* <HomeList title="autor nieznany" description="Dzieło autora" dateTime="data publikacji"/>*/}
            </div>
        );
    }
}
export default Home;

i Question.js

import React from "react";
import 'bootstrap/dist/css/bootstrap.min.css';

const HomeList = props => {
    return(
        <div className="card text-white bg-secondary mb-3">
            <div className="card-header">{props.dateTime}</div>
            <div className="card-body">
                <h5 className="card-title">{props.title}</h5>
                <p className="card-text">{props.description}.</p>
            </div>
        </div>
    )
}
export default HomeList;

 

komentarz 4 października 2019 przez kenjiro244 Dyskutant (8,600 p.)

Na początek masz 

import HomeList from "./binding/Home__List";

a twój plik nazywa się Question.js.

No i z którym question masz problem.

komentarz 4 października 2019 przez michal_php Stary wyjadacz (13,700 p.)

no dobra mój plik się inaczej nazywa 

  render() {
        if ( this.state.displayQuestions ) {
            questions = (
                <div>
                   {this.state.question.map((question,index)=>{
                       return <HomeList key={question.id} title={question.title} description={question.description} dateTime={question.dateTime} />
                   })}
                </div>
            )
        }

Z tym pierwszym question mam problem 

komentarz 4 października 2019 przez michal_php Stary wyjadacz (13,700 p.)

Konkretnie to zrobiłem coś takiego:

  if(this.state.displayQuestion){
             show = {
                 return <HomeForm/>
             }
        }

Tylko ,że cały czas podkreśla mi na czerwono show i błędy mam 

komentarz 4 października 2019 przez michal_php Stary wyjadacz (13,700 p.)

Działa leczę uważam ,że jest za kodu :

   render() {
        const posts = this.state.posts.map(el =>{
          return <HomeList key={el.id} title={el.title} description={el.description} dateTime={el.dateTime}/>;
        });
        if(this.state.displayQuestion){
            return( <div className="container">
                <h1>Home !</h1>
                <button className="btn btn-success btn-sm" onClick={this.displayQuestion}>Binding</button>
                <HomeForm/>
                {posts}
            </div>
            );
        }
        return(
            <div className="container">
                <h1>Home !</h1>
                <button className="btn btn-success btn-sm" onClick={this.displayQuestion}>Binding</button>
                {posts}
            </div>
        );
    }

jak by można to uprościć ?

komentarz 4 października 2019 przez kenjiro244 Dyskutant (8,600 p.)
render() {
     const posts = this.state.posts.map(el =>{
       return <HomeList key={el.id} title={el.title} description={el.description} dateTime={el.dateTime}/>;
     });
     if(){
         return( <div className="container">
             <h1>Home !</h1>
             <button className="btn btn-success btn-sm" onClick={this.displayQuestion}>Binding</button>
             {this.state.displayQuestion ? (<HomeForm/>) : null}
             {posts}
         </div>
         );
     }
 
 }

https://pl.reactjs.org/docs/conditional-rendering.html

Podobne pytania

0 głosów
1 odpowiedź 221 wizyt
pytanie zadane 23 grudnia 2018 w JavaScript przez Bakr Mądrala (6,850 p.)
0 głosów
0 odpowiedzi 236 wizyt
0 głosów
0 odpowiedzi 238 wizyt
pytanie zadane 22 stycznia 2023 w JavaScript przez Dobdo Użytkownik (570 p.)

92,623 zapytań

141,477 odpowiedzi

319,818 komentarzy

62,005 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...