我试图将 userIDs 的值映射到 listUserIds,然后使用 listUserIds 的值作为 listUser 函数中的键。但它只显示最后一个值。我做错了什么?
function Search(props) {
var listUserIds = []
const [userIDs, setUserIDs] = useState([]);
useEffect( async() => {
console.log('useEffect has been called!');
await userService.getUserAll().then(response => {
var listUser = response.data;
listUser.forEach(element => {
setUserIDs([element.id]);
});
})
.finally()
}, []);
Object.values(userIDs).forEach(x => listUserIds.push(x));
listUserIds.forEach(x => console.log(x));
const listUser = listUserIds.map((userId) =>
<div key={userId}>
<ThumbnailAdmin id={userId} ></ThumbnailAdmin>
</div>
)
return (
<div class="col-lg-9 mt-4 mt-lg-0" style={{marginLeft:"200px"}}>
<div class="row" >
<div class="col-md-12">
<div class="user-dashboard-info-box table-responsive mb-0 bg-white p-4 shadow-sm">
{listUser}
</div>
</div>
</div>
</div>
);
}
您可以像这样设置值。使用地图,您可以收集所有 ID,然后您可以更新状态。
await userService.getUserAll().then(response => {
var listUser = response.data;
let ids = listUser.map(element => element.id);
setUserIDs(ids);
})
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句