onClick, чтобы менять State и оно не функционирует

У меня есть составляющее меню. Этот, путь css меняется в типичное меню мобильного телефона с гамбургером и списком статей в колонне.

из-за default, поскольку это очевидно, одинокий он является гамбургером, и я хочу, чтобы, кликнув в этом гамбургере, он добавил некие классы к неким divs, для того, чтобы этот он появился.

Я думаю, что я не определяю постоянные величины как дебет того, чтобы быть (я думаю, что это неудача), но не знаю, как переходить.

я оставляю вам код компонента:

export class MenuComponent extends Component{


constructor(props){
       super(props);
       this.state  = {
           menuMobile: true
       }
   }
   openMenuMobile(){
       this.setState({menuMobile:false});
       console.log(this.state.menuMobile)
   }

render() {
    const clickedMenuToggle = this.state.menuMobile ? 'menu-toggle' : 'menu-toggle dark-menu';
    const clickedToggle = this.state.menuMobile ? 'toggle' : 'toggle opened';
    const clickedMenuMobile = this.state.menuMobile ? 'menu-mobile' : 'menu-mobile menu-mobile-opened';
    const clickedItemLi = this.state.menuMobile ? '' : 'item-li-opened';
    const clickedItemLia = this.state.menuMobile ? 'a-item-mobile' : 'a-item-mobile item-a-opened';

    return(
        <header>
            <div className={clickedMenuToggle}>
                <section className="content-mobile-menu">
                    <div className={clickedToggle}>
                        <div className="hamburger" onClick={this.openMenuMobile}>
                            <span></span>
                            <span></span>
                            <span></span>
                        </div>
                        <div className="ex">
                            <span></span>
                            <span></span>
                        </div>
                    </div>
                    <img className="logo-mobile" width="70" height="100" alt="Prrrcl Logo"
                         src={Logo} />
                    <div className="arrow-to-top">
                        <img
                            src="" alt={'Click to top'}/>
                    </div>
                </section>
            </div>
            <ul className={clickedMenuMobile}>
                <li className={clickedItemLi}>
                    <Link to={'/home'} className={clickedItemLia}><span>home</span></Link>
                </li>
            </ul>

            <nav className="header-nav not--clickable">
                <ul className="ul-menu">
                    <ItemMenu url={'/'} children={'home'}/>
                    <ItemMenu url={'/projects'} children={'projects'}/>

                    <li>
                        <img id="logo--header" width="90" alt="Prrrcl Logo" src="data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<!-- Created with Inkscape (http://www.inkscape.org/) -->

<svg
   xmlns:dc="http://purl.org/dc/elements/1.1/"
   xmlns:cc="http://creativecommons.org/ns#"
   xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#"
   xmlns:svg="http://www.w3.org/2000/svg"
   xmlns="http://www.w3.org/2000/svg"
   xmlns:sodipodi="http://sodipodi.sourceforge.net/DTD/sodipodi-0.dtd"
   xmlns:inkscape="http://www.inkscape.org/namespaces/inkscape"
   width="297mm"
   height="113mm"
   viewBox="0 0 297 113"
   version="1.1"
   id="svg8"
   inkscape:version="0.92.4 (5da689c313, 2019-01-14)"
   sodipodi:docname="logo.svg">
  <title
     id="title3743">prrrclLogo</title>
  <defs
     id="defs2">
    <pattern
       patternUnits="userSpaceOnUse"
       width="100.00125"
       height="39.839999"
       patternTransform="matrix(0.26458333,0,0,0.26458333,65.027774,126.65823)"
       id="pattern3717">
      <text
         id="text3715"
         y="30.24"
         x="-2.5599999"
         style="font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;font-size:40px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro Bold';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.99999994"
         xml:space="preserve"><tspan
           style="font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro Bold';stroke-width:0.99999994"
           y="30.24"
           x="-2.5599999"
           id="tspan3713"
           sodipodi:role="line">prrrcl</tspan></text>
    </pattern>
  </defs>
  <sodipodi:namedview
     id="base"
     pagecolor="#ffffff"
     bordercolor="#666666"
     borderopacity="1.0"
     inkscape:pageopacity="0.0"
     inkscape:pageshadow="2"
     inkscape:zoom="0.35"
     inkscape:cx="724.23528"
     inkscape:cy="619.42089"
     inkscape:document-units="mm"
     inkscape:current-layer="layer1"
     showgrid="false"
     inkscape:snap-text-baseline="false"
     inkscape:window-width="1366"
     inkscape:window-height="715"
     inkscape:window-x="-8"
     inkscape:window-y="-8"
     inkscape:window-maximized="1"
     height="209mm"
     inkscape:pagecheckerboard="false" />
  <metadata
     id="metadata5">
    <rdf:RDF>
      <cc:Work
         rdf:about="">
        <dc:format>image/svg+xml</dc:format>
        <dc:type
           rdf:resource="http://purl.org/dc/dcmitype/StillImage" />
        <dc:title>prrrclLogo</dc:title>
      </cc:Work>
    </rdf:RDF>
  </metadata>
  <g
     inkscape:label="Capa 1"
     inkscape:groupmode="layer"
     id="layer1"
     transform="translate(0,-184)">
    <g
       aria-label="®"
       style="font-style:normal;font-variant:normal;font-weight:bold;font-stretch:normal;font-size:32.17995834px;line-height:1.25;font-family:Arial;-inkscape-font-specification:'Arial Bold';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:0.80449891"
       id="text3741"
       transform="matrix(1.0462395,0,0,1.0462395,-4.9165828,58.771625)">
      <path
         d="m 286.1632,156.86193 q 0,3.22114 -1.61843,6.00232 -1.60271,2.78118 -4.38389,4.38389 -2.78117,1.60271 -6.00231,1.60271 -3.20543,0 -5.98661,-1.60271 -2.78117,-1.60271 -4.3996,-4.38389 -1.60271,-2.78118 -1.60271,-6.00232 0,-3.20542 1.60271,-5.9866 1.61843,-2.79689 4.3996,-4.3996 2.78118,-1.60272 5.98661,-1.60272 3.22114,0 6.00231,1.60272 2.78118,1.60271 4.38389,4.3996 1.61843,2.78118 1.61843,5.9866 z m -2.3255,0 q 0,-4.00678 -2.84403,-6.83509 -2.82832,-2.84403 -6.8351,-2.84403 -4.00678,0 -6.85081,2.84403 -2.82832,2.82831 -2.82832,6.83509 0,4.00679 2.82832,6.85082 2.84403,2.82831 6.85081,2.82831 4.00678,0 6.8351,-2.82831 2.84403,-2.84403 2.84403,-6.85082 z m -15.11579,-6.41085 h 5.7352 q 2.4355,0 3.51968,0.98991 1.09991,0.9742 1.09991,2.62405 0,1.28846 -0.83279,2.23123 -0.83278,0.94277 -2.62405,1.36702 0.73851,0.28283 1.08419,0.59709 0.4871,0.43996 1.02134,1.30417 0.0314,0.0628 2.0741,3.70823 h -3.77109 q -1.83841,-3.66109 -2.46692,-4.36817 -0.62852,-0.7228 -1.25703,-0.7228 -0.14142,0 -0.39282,0.0471 v 5.04383 h -3.18972 z m 3.18972,5.43666 h 1.38273 q 1.38273,0 1.9484,-0.43996 0.56566,-0.45568 0.56566,-1.16276 0,-0.70708 -0.54995,-1.14704 -0.53424,-0.45567 -1.83841,-0.45567 h -1.50843 z"
         style="font-style:normal;font-variant:normal;font-weight:900;font-stretch:normal;font-family:Arial;-inkscape-font-specification:'Arial Heavy';stroke-width:0.80449891"
         id="path824"
         inkscape:connector-curvature="0" />
    </g>
    <path
       inkscape:connector-curvature="0"
       id="path5271"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 62.051334,242.89398 c 0,-14.6403 -9.584591,-27.48991 -24.856753,-27.48991 -7.688743,0 -13.586962,3.68633 -16.74672,7.8994 h -0.315976 v -6.42492 H 3.7011411 v 77.73006 H 20.974491 V 263.5377 h 0.210684 c 3.26509,4.52895 9.479275,7.26743 15.904124,7.26743 15.798783,0 24.962087,-13.27098 24.962087,-27.91115 z m -16.746703,0 c 0,6.84607 -4.107686,13.58695 -12.323058,13.58695 -7.794075,0 -12.639035,-6.63549 -12.639035,-13.48167 0,-6.63549 4.84496,-13.48166 12.639035,-13.48166 8.215372,0 12.323058,6.63548 12.323058,13.37638 z" />
    <path
       inkscape:connector-curvature="0"
       id="path5273"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 107.5782,215.82534 c -0.84264,-0.31648 -2.31715,-0.42098 -3.68638,-0.42098 -6.424851,0 -11.58579,3.79172 -14.21892,9.05792 h -0.210682 v -7.58343 H 72.820819 v 52.452 h 17.273356 v -26.96324 c 0,-4.31837 3.054427,-11.9018 12.323065,-11.9018 1.36921,0 2.84377,0.10545 4.42366,0.52647 z" />
    <path
       inkscape:connector-curvature="0"
       id="path5275"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 149.33802,215.82534 c -0.84263,-0.31648 -2.31716,-0.42098 -3.68638,-0.42098 -6.42485,0 -11.58578,3.79172 -14.21891,9.05792 h -0.21069 v -7.58343 h -16.64137 v 52.452 h 17.27336 v -26.96324 c 0,-4.31837 3.05444,-11.9018 12.32305,-11.9018 1.36923,0 2.84378,0.10545 4.42367,0.52647 z" />
    <path
       inkscape:connector-curvature="0"
       id="path5277"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 191.09784,215.82534 c -0.84264,-0.31648 -2.31715,-0.42098 -3.68638,-0.42098 -6.42483,0 -11.58578,3.79172 -14.2189,9.05792 h -0.21068 v -7.58343 h -16.6414 v 52.452 h 17.27334 v -26.96324 c 0,-4.31837 3.05445,-11.9018 12.32305,-11.9018 1.36924,0 2.84379,0.10545 4.42367,0.52647 z" />
    <path
       inkscape:connector-curvature="0"
       id="path5279"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 242.38139,222.25015 c -4.10769,-4.21297 -12.00709,-7.05676 -19.48517,-7.05676 -16.32542,0 -29.28044,10.84847 -29.28044,27.91116 0,17.37867 12.8497,27.91128 29.38577,27.91128 7.68872,0 15.0615,-2.52781 19.37984,-6.74089 l -9.5846,-11.69111 c -2.10652,2.52781 -5.89821,3.8971 -9.37395,3.8971 -7.58341,0 -12.32305,-6.10893 -12.32305,-13.37638 0,-7.26744 4.84495,-13.48157 12.1124,-13.48157 3.47573,0 7.26744,1.68517 9.1633,4.21298 z" />
    <path
       inkscape:connector-curvature="0"
       id="path5281"
       style="font-style:normal;font-variant:normal;font-weight:normal;font-stretch:normal;font-size:10.58333302px;line-height:1.25;font-family:'Avenir Next LT Pro';-inkscape-font-specification:'Avenir Next LT Pro';letter-spacing:0px;word-spacing:0px;fill:#000000;fill-opacity:1;stroke:none;stroke-width:2.63313174"
       d="m 267.01764,269.33055 v -79.62591 h -17.484 v 79.62591 z" />
  </g>
</svg>
"/>
                    </li>
                    <ItemMenu url={'/cv'} children={'cv'}/>

                    <ItemMenu url={'/contact'} children={'contact'}/>
                </ul>
            </nav>
        </header>
    )
}

}

0
задан 20.03.2019, 12:10
1 ответ

Ты должен создавать binding в строителе для того, чтобы он смог брать функцию. Так как this в этом случае undefined, так как в JSX он отличается и поэтому он не призывает ее funciГіn.

constructor(props){
       super(props);
       this.state  = {
           menuMobile: true
       }
this.openMenuMobile = this.openMenuMobile.bind(this)
   }
2
ответ дан 02.12.2019, 05:22
  • 1
    Гениальный! точно то, в чем он нуждался. Большое спасибо. – Adrián 20.03.2019, 12:25
  • 2
    Не за что!!! @adrian. – Wilfredo 20.03.2019, 12:26

Теги

Похожие вопросы