如果用户列表与以下数组中的任何ID匹配,我想将按钮更改为unfollow,否则它应该跟随按钮。
我的代码中的术语:用户:它是一个存储登录用户数据的存储器。它是一个数组,当用户跟随另一个用户时,用户id被存储在这里跟随者:它包含数据库中每个用户
这是我试过的:
{user.following?
user?.following?.map((val, id) => {
if (val === follower._id) {
return <button className='button fc-button' onClick={() => { handleUnFollow(follower._id) }} key={id}>
unfollow
</button>
} else {
return <button className='button fc-button' onClick={() => { handleFollow(follower._id) }} key={id}>
follow
</button>
}
})
: <button className='button fc-button' onClick={() => { handleFollow(follower._id) }} key={id}>
follow
</button>}
1条答案
按热度按时间shyt4zoc1#
您可以使用**Array.prototype.includes()方法来检查数组中是否存在特定的值。如果 user.following 数组不为空,则可以使用Array.prototype.map()**来循环访问追随者数组,并为每个追随者返回相应的按钮。
下面是如何在代码中实现此功能的示例:
如果user.following数组为null,则可以通过在map()方法后添加else块来返回“follow”按钮: