首页 > 解决方案 > 如何从数组的特定对象中获取 id?

问题描述

我需要从一个包含 141 部电影的数组中显示,这是 10 部最古老的电影。在我这样做之后,我需要为他们每个人都制作一个链接到他们的页面,并附上电影的描述。所以,我用它来获取最古老的电影:

$movies = json_decode(file_get_contents('https://raw.githubusercontent.com/yegor-sytnyk/movies-list/master/db.json'))->movies;

$numbers = array_column($movies, 'year','title');
$numbers2=asort($numbers, SORT_NUMERIC);
$numbers3=array_slice($numbers, 0, 10);

为了制作链接,我使用了这个:

<?php foreach($numbers3 as $key=>$value){?>
<a href="single.php?movie_id"><?php echo "$key-$value",'<br>';?></a>
<?php }?>

还有 single.php 页面:

$movieId=$_GET['movie_id'];
if(isset($movieId)&& $movieId && $movieId !=""){
    function get_movie($value){
        global $movieId;
        if($movieId==$value->id){
            return TRUE;
        }else{
            return FALSE;
        }
    }
    $moviesFilter=array_filter($movies, "get_movie", ARRAY_FILTER_USE_BOTH);
    if(count($moviesFilter)>0){
        $movie= reset($moviesFilter);
    }?>

 <?php}?>

在我按下它们后,我无法从那 10 部特定电影中找到显示内容的 id ...:(

标签: php

解决方案


我宁愿使用电影的真实 ID 作为参数:

<?php

$data = json_decode(file_get_contents('https://raw.githubusercontent.com/yegor-sytnyk/movies-list/master/db.json'), true);
$movies = array_key_exists('movies', $data) ? $data['movies'] : [];
$filtered_movies = $movies;

uasort( $filtered_movies, function ($a, $b) {
    return $a['year'] - $b['year'];
});
$filtered_movies = array_slice($filtered_movies, 0, 10);

foreach ($filtered_movies as $id => $movie) {
?>
    <a href="single.php?movie_id=<?= $id ?>"><?= $movie['year']." - ".$movie['title'] ?></a>
<?php
}

json_decode 提供解码为关联数组,而不是对象。对于这种情况,这是更有利的解决方案。现在,通过唯一 ID 获取电影也更漂亮single.php

$movieId = $_GET['movie_id'];                                                   
$data = json_decode(file_get_contents('https://raw.githubusercontent.com/yegor-sytnyk/movies-list/master/db.json'), true);
$movies = array_key_exists('movies', $data) ? $data['movies'] : [];             

if (array_key_exists($movieId, $movies)) {                                      
?>                                                                              
Movie details:<br>                                                              
Title: <?= $movies[$movieId]['title'] ?><br>                                    
Year: <?= $movies[$movieId]['year'] ?><br>                                      
Genres: <?= join(', ', $movies[$movieId]['genres']) ?><br>                      

<?php                                                                           
} else {                                                                        
?>                                                                              
    The desired movie does not exist.                                           
<?php                                                                           

}   

推荐阅读