如何获取Laravel集合中的元素索引

时间:2018-12-07 01:18:36

标签: php mysql laravel collections eloquent

如何检索集合中元素的索引? 我的代码:

$users = User::has('posts')->withCount('posts')->orderBy('posts_count')->take(50)->get();

if($users->contains(Auth::id())){
    //get the index of auth user id
 }

感谢帮助

2 个答案:

答案 0 :(得分:3)

您可以使用集合search()方法:https://laravel.com/docs/5.7/collections#method-search

$users = User::has('posts')->withCount('posts')->orderBy('posts_count')->take(50)->get();

$userIndex = $users->search(function($user) {
    return $user->id === Auth::id();
});

请小心,因为索引可能为0:

// DON'T do this
if($userIndex) {
    // this will get skipped if the user is the first one in the collection
}

// Do this instead
if($userIndex !== false) {
    // this will work
}

答案 1 :(得分:-2)

$users = User::has('posts')->withCount('posts')->orderBy('posts_count')->take(50)->get();

// this return a collection. So can do an if like this: $userIndex->count() > 0
$userIndex = $users->filter(function($user) {
    return $user->id === Auth::id()
});