2016-03-19 61 views
1

我有一個嵌套在名爲「Create」的組件內的按鈕,它必須觸發改變app.js中的狀態並呈現全新視圖的狀態更改。React-Router - 將方法傳遞給子組件

我似乎無法將方法changeHPage從app.js傳遞給Create組件。我正在使用React-Router,通常我只是編寫<App changeHPage={this.changePage}>將該方法傳遞給其子組件,並使用this.props.changeHpage調用它,但在使用React路由器時,我無法通過此方法傳遞道具。

任何關於如何使用React路由器將方法傳遞給子組件的幫助將非常感謝。我的代碼可以在下面找到。

app.js:

/* STRICT MODE: See `../../server.js` */ 
'use strict'; 

/* GLOBAL REACT REQUIRES */ 
// React.js 
const React = require('react'); 
// React-DOM for HTML rendering 
const ReactDOM = require('react-dom'); 
// React router for dynamic pathing. Has several component features that need to be required to use. 
const ReactRouter = require('react-router'); 
// 4 components pulled from ReactRouter: 
const Router = ReactRouter.Router; 
const Route = ReactRouter.Route; 
const Navigation = ReactRouter.Navigation; 
const Link = ReactRouter.Link; 
const browserHistory = ReactRouter.browserHistory; 

/* Relative paths to external components */ 
const auth = require('./helpers/auth.js'); 
const requireAuth = require('./helpers/requireauth.js'); 
const About = require('./components/about.js'); 
const Login = require('./components/login.js'); 
const Logout = require('./components/logout.js'); 
const Signup = require('./components/signup.js'); 
const Header = require('./components/header.js'); 
const Create = require('./components/create.js'); 
const NotFound = require('./components/notfound.js'); 
const Veri = require('./components/veri.js'); 


/* React App Creation */ 
const App = React.createClass({ 
    // Declares the initial state when app is loaded 
    getInitialState : function() { 
    return { 
     loggedIn: auth.loggedIn(), 
     change: true, 
     phoneNumber: {} 
    } 
    }, 

    // Updates state when login is trigger 
    updateAuth : function(loggedIn) { 
    this.setState({ 
     loggedIn: loggedIn 
    }) 
    }, 



    changeHPage: function() { 
    this.state.change = !this.state.change; 
    this.setState({ 
     change: !this.state.change 
    }); 
    console.log("changePage On HomePage Pressed"); 
    this.context.router.push('/') 
    }, 




    // Login even triggered and sent to back-end 
    componentWillMount : function() { 
    auth.onChange = this.updateAuth 
    auth.login() 
    }, 


    addNumber: function(phonenumber){ 

    this.state.phonenumber = phonenumber 
    this.setState() 

    }, 


    // Renders App and all of its children 
    render : function() { 

    <div className="Detail"> 
     {this.props.children && React.cloneElement(this.props.children, { 
      changeHPage: this.changeHPage 
     })} 
     </div> 

    var firstView; 


     {if(this.state.change) { 
     firstView = <div> 
     <div className="row"> 
     <Veri> This is a child of Veri </Veri> 
     <Header details="Hi, I'm Plantee"/> 
     <section className="col s12"> 
     <ul> 
      {this.state.loggedIn ? (
       <div> 
       <li><Link to="/logout">Log out</Link> </li> 
       <li><Link to="/create">Create Your Plantee</Link></li> 
       {/*<Create> <Veri/> </Create>*/} 
      </div> 
      ) : (
       <div> 
       <li><Link to="/login">Log In</Link></li> 
       <li><Link to="/signup">Sign up</Link></li> 
      </div> 
      )} 
      <li><Link to="/about">About</Link></li> 
     </ul> 
     {this.props.children || <p>You are {!this.state.loggedIn && 'not'} logged in.</p>} 
     </section> 
     </div> </div> 

    } else { 
     firstView= <div>'Hello'</div> 
    } 
     return React.cloneElement(
     firstView, 
     {switch: this.changeHPage} 
    ) 

    }} 

}) 





/* React router initialization */ 
var routes = (
    <Router history={browserHistory}> 
    <Route path="/" component={App} > 
    <Route path="header" component={Header} /> 
     <Route path="login" component={Login} /> 
     <Route path="logout" component={Logout} /> 
     <Route path="create" component={Create} change={App.changeHPage} /> 
     <Route path="signup" component={Signup} /> 
     <Route path="about" component={About} /> 
     <Route path="very" component={Veri} /> 
    </Route> 
    <Route path="*" component={NotFound} /> 
    </Router> 
) 

ReactDOM.render(routes, document.querySelector('#container')) 

create.js:

const React = require('react'); 
const ReactDOM = require('react-dom'); 
const auth = require('../helpers/auth') 
const Veri = require('./veri.js'); 
const App = require('../app.js'); 

const ReactRouter = require('react-router'); 
// 4 components pulled from ReactRouter: 
const Router = ReactRouter.Router; 
const Route = ReactRouter.Route; 
const Navigation = ReactRouter.Navigation; 
const Link = ReactRouter.Link; 
const browserHistory = ReactRouter.browserHistory; 


const Create = React.createClass({ 

    getInitialState: function(){ 
    return {checked: false} 
    }, 
    handleClick: function(event) { 
    event.preventDefault(); 
    this.setState({checked: !this.state.checked}) 

    let phonenumber = { 
     phonenumber: this.refs.phonenumber.value 
    } 

    }, 

    showVerification : function(event) { 
    event.preventDefault(); 

    }, 


    remove(e) { 
    e.preventDefault(); 
    console.log(this.props); 
    }, 

    render : function(){ 

    var msg; 
    {if(this.state.checked) { 
     msg = <div><Veri text={'Your verification code is '} code={'code'}/> <form className="gotIt" onSubmit={this.props.changeHpage} > 
     <input type="Submit" value="Got It" /> 
     </form> </div> 
    } 
    else { 
     msg = <Veri details={''}/> 
    }} 

    return (

     <div> 
     <h1>Create Your Plantee</h1> 

     <h2>Please Enter Your Phone Number</h2> 
     <p>You will recieve a phone call in order to verify that you are capable of raising a plantee</p> 



     <form className="telephoneNumber" onSubmit={this.handleClick}> 
     <input id="phonenumber" ref="phonenumber" type="tel" /> 
     <input type="Submit" /> 
     </form> 
     <div> {msg} </div> 

     <h3>{this.props.children}</h3> 


     </div> 
    ) 
    } 
}) 

module.exports = Create; 

回答

0

請看下面GitHub的問題: https://github.com/reactjs/react-router/issues/1857 這是直接取自:ryanflorence

通常,如果您'通過道路邊界傳遞道具你的父母路線完全知道它渲染的是什麼:

<Route path="/inbox" component={Inbox}> 
    <Route path=":messageId" component={Message}/> 
    <IndexRoute component={InboxStats}/> 
</Route> 

const Inbox = React.createClass({ 
    render() { 
    return (
     <div> 
     {/* this is only ever `Message`, except the weird case 
      of `InboxStats` which doesn't need the prop */} 
     {React.cloneElement(this.props.children, { 
      onDelete: this.handleMessageDelete 
     })} 
     </div> 
    ) 
    } 
}) 

相反,使用無組件路由,只是做「正常」的反應的東西。

<Route path="/inbox" component={Inbox}> 
    {/* no more `Message` */} 
    <Route path=":messageId"/> 
</Route> 

const Inbox = React.createClass({ 
    render() { 
    const { messageId } = this.props.params 
    return (
     <div> 
     {messageId ? (
      <Message onDelete={this.handleMessageDelete}/> 
     ) : (
      <InboxStats/> 
     )} 
     </div> 
    ) 
    } 
}) 

cloneElement是不是對自己不好的做法,但它往往是一個指標,有更多的做一些事情的簡單方法。

+0

您可以請我提供一些關於如何使用this.props.params從創建組件內實現call changePage的更具體指導嗎? – CodeYogi

+0

檢查,看看這是否有幫助... – JordanHendrix

+0

我無法實現此解決方案,但感謝您的幫助! – CodeYogi