React - 在地图功能中生成不同的图标
React - Generating different Icons within a map function
我有一个侧边栏组件,其列表项是在地图函数内部生成的(从 api 获取的电影类型)。我想在每种电影类型旁边有一个不同的图标,但一直无法找到一种方法来为地图功能的每个 运行 创建一个不同的图标。
我的想法是
1st:按照我希望它们显示的顺序制作一个我想显示的图标数组。
const icons = [
"AiOutlineHome ",
"FaUserNinja",
"GiSwordman",
"GiBabyFace",
"FaLaughBeam",
"GiPistolGun",
"GiPineTree",
"GiDramaMasks",
"GiFamilyHouse",
"GiElfEar",
"GiScrollUnfurled",
"GiScreaming",
"GiMusicalNotes",
"GiMagnifyingGlass",
"FaRegKissBeam",
"GiMaterialsScience",
"GiHalfDead",
"GiGreatWarTank",
"GiCowboyBoot",
];
然后在我的地图函数中为每个列表项生成不同的图标
{movieGenres.map((genre) => {
return (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
*<GENERATE ICON HERE />*
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
);
})}
是否可以实用地创建这样的组件?这样我就可以避免在需要不同图标时单独创建每个列表项。
你可以直接拿你的流派索引来获取图标。索引是 map()
函数回调的第二个参数:
{movieGenres.map((genre, idx) => (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
<Icon icon={icons[idx]} />
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
))}
Icon
组件会根据您使用的图标类型呈现图标。
编辑:
因为你想使用 react-icons
你需要导入实际的图标组件而不是仅仅使用字符串:
import {AiOutlineHome} from "react-icons/ai";
import {FaUserNinja} from "react-icons/fa";
// ....
const icons = [
AiOutlineHome,
FaUserNinja,
// ...
];
并渲染它们:
{movieGenres.map((genre, idx) => {
// must be a capitalized name in order for react to treat it as a component
const Icon = icons[idx];
return (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
<Icon />
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
)
})}
我有一个侧边栏组件,其列表项是在地图函数内部生成的(从 api 获取的电影类型)。我想在每种电影类型旁边有一个不同的图标,但一直无法找到一种方法来为地图功能的每个 运行 创建一个不同的图标。
我的想法是 1st:按照我希望它们显示的顺序制作一个我想显示的图标数组。
const icons = [
"AiOutlineHome ",
"FaUserNinja",
"GiSwordman",
"GiBabyFace",
"FaLaughBeam",
"GiPistolGun",
"GiPineTree",
"GiDramaMasks",
"GiFamilyHouse",
"GiElfEar",
"GiScrollUnfurled",
"GiScreaming",
"GiMusicalNotes",
"GiMagnifyingGlass",
"FaRegKissBeam",
"GiMaterialsScience",
"GiHalfDead",
"GiGreatWarTank",
"GiCowboyBoot",
];
然后在我的地图函数中为每个列表项生成不同的图标
{movieGenres.map((genre) => {
return (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
*<GENERATE ICON HERE />*
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
);
})}
是否可以实用地创建这样的组件?这样我就可以避免在需要不同图标时单独创建每个列表项。
你可以直接拿你的流派索引来获取图标。索引是 map()
函数回调的第二个参数:
{movieGenres.map((genre, idx) => (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
<Icon icon={icons[idx]} />
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
))}
Icon
组件会根据您使用的图标类型呈现图标。
编辑:
因为你想使用 react-icons
你需要导入实际的图标组件而不是仅仅使用字符串:
import {AiOutlineHome} from "react-icons/ai";
import {FaUserNinja} from "react-icons/fa";
// ....
const icons = [
AiOutlineHome,
FaUserNinja,
// ...
];
并渲染它们:
{movieGenres.map((genre, idx) => {
// must be a capitalized name in order for react to treat it as a component
const Icon = icons[idx];
return (
<li key={genre.id} className="nav-text">
<button
className="genre-btn"
onClick={() => genreSelectionHandler(genre.id)}
>
<Icon />
<span className="nav-item-title">{genre.name}</span>
</button>
</li>
)
})}