0

我正在构建一个评级组件,它接收许多图标并使用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

在此处输入图像描述

4

2 回答 2

1

如果没有看到您正在使用的数据看起来像这样,这很难回答,但我会试一试。我假设您想要的是当用户单击星号将评分设置在 1 到 5 之间时,您希望以实心星的形式向他们显示他们的评分。如果是这种情况,您可以使用rating来确定是向用户显示当前评级还是他们设置的评级,然后根据需要使用正确的图标。

这可以通过将正确的字符串设置为变量然后使用它来代替您的图标 JSX 标记名称来完成。基本上,如果用户设置了评分,rating将不再是null并且您可以断言您需要填充星。使用该逻辑将变量分配给您想要的字符串。const Star = rating ? 'FaStar' : 'FaHalfStar'

import React, { useState } from 'react'
import { FaStarHalf, FaStar } from 'react-icons/fa'

import './styles/Rater.css'

const Rater = ({ iconCount }) => {
    const [rating, setRating] = useState(null)
    const [hover, setHover] = useState(null)
    // check if user has set a rating by clicking a star and use rating to determine icons
    const Star = rating ? 'FaStar' : 'FaHalfStar'

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>
                            // Use 'Star' variable here which is assigned 'FaStar' or 'FaHalfStar' and will display a half star or a full star
                            <Star
                                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
于 2020-12-18T23:47:21.057 回答
0

我能够弄清楚,使用与@CaseyC 使用的代码类似的代码,我需要找到相应的半星,而不是我试图使用的全星

import React, { useState } from 'react'
import { FaRegStarHalf, FaStarHalf } from 'react-icons/fa'

import './styles/Rater.css'

const Rater = ({ iconCount }) => {
    const [rating, setRating] = useState(null)
    const [hover, setHover] = useState(null)
    // check if user has set a rating by clicking a star and use rating to determine icons
    const Star = rating ? FaStarHalf : FaRegStarHalf

    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>
                                <Star
                                    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
于 2020-12-19T00:30:07.907 回答