问题描述
我的代码中带有以下图标:
<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函数中的其他图标。
为清楚起见,我在这里使用了功能组件。