作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
所以我有一个评级系统,我已经编写了以下代码来显示要显示的星星数量,尽管它很长,所以我正在尝试找到一种方法来缩短它。
我不知道是否有某种算法先相乘然后加上空星之类的?
const rating = (recipe) => {
const value = (recipe.rating / recipe.votes.length).toFixed(1);
if (value >= 4.9)
return (
<>
<FaStar />
<FaStar />
<FaStar />
<FaStar />
<FaStar />
</>
);
if (value >= 4.5)
return (
<>
<FaStar />
<FaStar />
<FaStar />
<FaStar />
<FaStarHalfAlt />
</>
);
if (value >= 4)
return (
<>
<FaStar />
<FaStar />
<FaStar />
<FaStar />
<FaRegStar />
</>
);
if (value >= 3.5)
return (
<>
<FaStar />
<FaStar />
<FaStar />
<FaStarHalfAlt />
<FaRegStar />
</>
);
if (value >= 3)
return (
<>
<FaStar />
<FaStar />
<FaStar />
<FaRegStar />
<FaRegStar />
</>
);
if (value >= 2.5)
return (
<>
<FaStar />
<FaStar />
<FaStarHalfAlt />
<FaRegStar />
<FaRegStar />
</>
);
if (value >= 2)
return (
<>
<FaStar />
<FaStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
</>
);
if (value >= 1.5)
return (
<>
<FaStar />
<FaStarHalfAlt />
<FaRegStar />
<FaRegStar />
<FaRegStar />
</>
);
if (value >= 1)
return (
<>
<FaStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
</>
);
if (value >= 0.5)
return (
<>
<FaStarHalfAlt />
<FaRegStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
</>
);
return (
<>
<FaRegStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
<FaRegStar />
</>
);
};
最佳答案
如果你真的想缩短它:
const rating = (recipe) => {
const value = (recipe.rating / recipe.votes.length).toFixed(1);
const stars = Array.from(Array(5)).map(() => <FaRegStar/>);
if (value >= 4.9) {
return stars.map(() => <FaStar/>);
}
for (let i = 0; i < Math.round(value); i++) {
stars[i] = i > value - 1 ? <FaStarHalfAt/> : <FaStar/>;
}
return stars;
};
这样会更容易理解(评分 >= 4.9 时会显示 5 星):
const rating = (recipe) => {
let value = (recipe.rating / recipe.votes.length).toFixed(1);
if (value >= 4.9) {
return Array.from(Array(5)).map(() => <FaStar/>);
}
const stars = [];
while (value >= 1) {
stars.push(<FaStar/>);
value--;
}
if (value >= 0.5) {
stars.push(<FaStarHalfAt/>);
}
while (stars.length < 5) {
stars.push(<FaRegStar/>);
}
return stars;
};
或者更短一点但仍然可以理解:
const rating = (recipe) => {
let value = (recipe.rating / recipe.votes.length).toFixed(1);
if (value >= 4.9) {
return Array.from(Array(5)).map(() => <FaStar/>);
}
const stars = [];
while (stars.length < 5) {
stars.push(value >= 1
? <FaStar/>
: value >= 0.5
? <FaStarHalfAt/>
: <FaRegStar/>);
value--;
}
return stars;
};
关于javascript - 有什么办法可以缩短这段代码吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/67547898/
我是一名优秀的程序员,十分优秀!