首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Button组件的onclick与事件属性

Button组件的onclick与事件属性
EN

Stack Overflow用户
提问于 2022-03-28 18:48:47
回答 1查看 45关注 0票数 1

我是非常新的反应和前端的发展。

最近我遇到了一些让我困惑的事情。

为什么下面的代码片段能够正常工作:

代码语言:javascript
复制
import React, { useState } from "react";
import "./styles.css";
import Button from "./Button";

export default function App() {
  const [buttonsOnCanvas, setButtonsOnCanvas] = useState([]);
  return (
    <div className="App">
      <Button
        event={() => {
          setButtonsOnCanvas([...buttonsOnCanvas, <Button />]);
        }}
      />
      <div className="canvas">{buttonsOnCanvas}</div>
    </div>
  );
}

但不是这个:

代码语言:javascript
复制
import React, { useState } from "react";
import "./styles.css";
import Button from "./Button";

export default function App() {
  const [buttonsOnCanvas, setButtonsOnCanvas] = useState([]);

  function handleAddButtonClick() {
    setButtonsOnCanvas([...buttonsOnCanvas, <Button />]);
  }

  return (
    <div className="App">
      <Button
        onClick={() => handleAddButtonClick()}
      />
      <div className="canvas">{buttonsOnCanvas}</div>
    </div>
  );
}

Button.js代码:从“React”导入react;

代码语言:javascript
复制
export default ({ name = "Add Button", event }) => (
  <button onClick={event}>{name}</button>
);

区别似乎在于onClick与事件属性之间的区别。在事件版本中,单击web浏览器中实例化的初始按钮将不断添加新的按钮实例。对于onClick,什么都不会发生。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-03-28 19:49:37

道具'onCLick‘不存在于Button组件中,这就是它不能工作的原因。更改您的Button.js

代码语言:javascript
复制
  export default ({ name = "Add Button", event }) => (
      <button onClick={event}>{name}</button>
  );

通过

代码语言:javascript
复制
  export default ({ name = "Add Button", onClick }) => ( 
      <button onClick={onClick}>{name}</button>
  );

现在,您可以在onClick中使用Button而不是事件。然后在应用程序组件中

代码语言:javascript
复制
  export default function App() {
  const [buttonsOnCanvas, setButtonsOnCanvas] = useState([]);

  function handleAddButtonClick() {
    setButtonsOnCanvas([...buttonsOnCanvas, <Button />]);
  }

  return (
    <div className="App">
      <Button
        onClick={handleAddButtonClick} // Better avoid anonymous function
      />
      <div className="canvas">{buttonsOnCanvas}</div>
    </div>
  );
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71652282

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档