我在React中使用FlowRouter / Meteor,并试图将FlowRouter.go方法传递给react按钮,以在按下按钮时导航到新页面。我想这样做是为了将按钮保留为可重用组件,但仍在努力找出如何将FlowRouter.go方法传递到无状态功能组件中。这是我现在拥有的简化版本:

import React, { Component } from 'react';
import { FlowRouter } from 'meteor/kadira:flow-router';

const ParentComponent = () => {
  // define text and styles here
  return (
    <div>
      <Button text={text} style={styles} action={FlowRouter.go("Register")}/>
    </div>
  );
}

然后是我的按钮组件:
import React, { Component } from 'react';

// Call to action button
const Button = ({text, style, action}) => {
  return (
    <button className="btn" style={style} onClick={() => action()}>
      {text}
    </button>
  );
}

Button.propTypes = {
  text: React.PropTypes.string.isRequired,
  style: React.PropTypes.object,
  action: React.PropTypes.func
};

Button.defaultProps = {
  text: "A button.",
  style: {
    height: "100%",
    width: "100%",
  },
  action: null
};

export default Button

有谁知道将第三方库中的方法加载到React功能组件中需要什么语法?

最佳答案

您需要传递一个函数。您实际上是在通过调用FlowRouter.go执行FlowRouter.go("Register")函数。

试试这个:

const ParentComponent = () => {
  // define text and styles here
  return (
    <div>
      <Button text={text} style={styles} action={() => FlowRouter.go("Register")}/>
   </div>
  );
}

另外...由于action是一个函数,您可以将其直接传递给onClick,如下所示:
<button className="btn" style={style} onClick={action}>

08-15 18:37