通过事件道具传递所有参数

如何解决通过事件道具传递所有参数

我有一个 <Link /> 组件,它本质上只是一个样式化的 <a /> 标签。它需要一个 href 道具以及一个可选的 onClick。如果传入 onClick,我想 preventDefault() 事件并调用 onClick 道具。

目前我的组件看起来像这样:

<a
    aria-label={ ariaLabel }
    className={ className }
    href={ href }
    onClick={ handleOnClick }
    target={ target }
    { ...rest }
>
    {children}
</a>

然后我有以下功能

const handleOnClick = event => {
    event.preventDefault();
    onClick(event);
};

除非使用 onClick 传入参数,否则这可以正常工作。我的 handleOnClick 函数只是将事件传回,参数丢失了。如何将可能已传入的任何和所有参数传回?

解决方法

这是我的解决方案:

const handleOnClick = (event,...args) => {
    // here args will be an array.
    // so loop through it for additional arguments
    event.preventDefault();
    onClick(event);
};

,

我最终完全走向了不同的方向。问题是使用我的组件库的应用程序需要从我的组件返回某些参数,并带有 onClick 之类的事件。 vendorIdaction 等参数。因此,与其在我的组件中创建 vendorIdaction 道具,当​​您处理一个不应该关心 vendorId 是什么的通用组件时,这实际上没有意义,我创建了一个 eventData 道具,它允许消费者在一个对象中设置他们想要的任何数据,并且该对象将被传递回 onClick

我目前正在处理的组件是一个菜单,所以我在我的 eventData 中添加了一个 menuItems 属性:

menuItems: PropTypes.arrayOf(
    PropTypes.shape({
        badge: PropTypes.number,eventData: PropTypes.objectOf(PropTypes.any),group: PropTypes.string,icon: PropTypes.oneOf([...ICONS,'coin']),id: PropTypes.string.isRequired,label: PropTypes.string.isRequired,}),),

然后每个菜单按钮都有这个onClick

<SimpleMenuButton onClick={ event => handleOnClick(event,item.eventData) }>

... 然后是 handleOnClick 处理程序:

const handleOnClick = (event,data) => {
    onClick(event,data);
};

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?