我正在构建一个评级组件,它接收许多图标并使用react-icons
. 然而,我的问题是关于我想要实现的功能。目前,我使用的反应图标FaStarhalf
是一个预填充的半星,我翻转它以制造我创造了半星的错觉。这很容易使用并且可以完成我需要它做的事情,但是,我想实现一种更好的方式来在您选择星星时进行显示。不幸react-icons
的是,我似乎没有能力一路填充图标。FaRegStarHalf
是另一个组件,react-icons
它基本上是从星星上剪下来的,但是,你不能填充它。
所以我问你的问题。是否有可能在我的FaStarHalf
组件内部,当它被点击时,将每一个更改FaStarHalf
为它的填充对应物react-icons
?我可以将组件从自身内部更改为不同的组件吗?
Rater
import React, { useState } from 'react'
import { FaStarHalf } from 'react-icons/fa'
import './styles/Rater.css'
const Rater = ({ iconCount }) => {
const [rating, setRating] = useState(null)
const [hover, setHover] = useState(null)
return (
<div>
{[...Array(iconCount), ...Array(iconCount)].map((icon, i) => {
const value = (i + 1) / 2
return (
<label>
<input
type='radio'
name='rating'
value={value}
onClick={() => {
console.log(`value => `, value)
return setRating(value)
}}
/>
<div className='star-container'>
<div>
<FaStarHalf
className={i % 2 ? 'star-left' : 'star'}
color={value <= (hover || rating) ? '#ffc107' : '#e4e5e9'}
onMouseEnter={() => setHover(value)}
onMouseLeave={() => setHover(null)}
/>
</div>
</div>
</label>
)
})}
</div>
)
}
export default Rater
FaHalfStar
FaRegHalfStar