流星和反应:模板事件

时间:2015-04-07 20:09:19

标签: meteor reactjs meteor-react

我正在玩Meteor和react-meteor。但是,我似乎无法理解模板事件处理在使用react时是如何工作的(如果它甚至可以)。

的index.html:

<head>
  <title>reactjs</title>
</head>
<body>
  <h1>Welcome to Meteor!</h1>
  {{> FormTest}}
</body>

LIB /组件/ testform.jsx:

var FormTest = ReactMeteor.createClass({
  templateName: "FormTest",
  render: function() {
    return (
      <div>
        <button className="my-button">My byutton</button>
      </div>
    );
  }
});

index.js:

if (Meteor.isClient) {
  Template.FormTest.events({
    "click .my-button": function (event, template) {
      alert("My button was clicked!");
    }
  });
}

我一无所获。

我的代码或方法有问题吗?如果接近,处理事件的正确方法是什么?

1 个答案:

答案 0 :(得分:3)

如果您在此处添加事件处理程序:

<button className="my-button" onClick={this.handleClick}>My button</button>

然后,您可以在testform.jsx文件中执行此操作:

handleClick: function(e) {
        if (Meteor.isClient) {
            e.preventDefault();
            console.log("My button was clicked");
        }
}

我也在测试与Meteor的React,但这似乎有用。