fortawesome / react-fontawesome软件包更改图标onclick

问题描述

我的代码中带有以下图标:

<FontAwesomeIcon id="star" onClick={this.handleClick} icon={hollowstar} size="lg" />

我需要将图标从Hollowstar更改为solidstar onclick。如何做到这一点?

解决方法

您可以执行以下操作:

import { faStar as fasFaStar } from '@fortawesome/free-solid-svg-icons';
import { faStar as farFaStar } from '@fortawesome/free-regular-svg-icons';

// ...

const [star,setStar] = useState(farFaStar);

// ...

<FontAwesomeIcon
  onClick={() => {
    setStar(fasFaStar);
  }}
  icon={star}
  // Other props...
/>

因此,在代码中,我们导入了具有不同样式的相同星形图标,如此处的文档所述:https://github.com/FortAwesome/react-fontawesome#how-do-i-import-the-same-icon-from-two-different-styles

由于图标只是一个对象,您可以将其保存为状态并将状态更新为onClick函数中的其他图标。

为清楚起见,我在这里使用了功能组件。