Как я могу объединить нумерацию страниц и фильтрацию в php? - PullRequest
0 голосов
/ 28 апреля 2020

Я хотел бы отобразить некоторые продукты из базы данных и использовать нумерацию страниц, а также флажки для фильтрации. Моя нумерация работает нормально. И когда я нажимаю флажки и нажимаю «отправить», я получаю отфильтрованные результаты на первой странице. Однако, когда я перехожу на вторую или любую другую страницу, флажки автоматически снимаются, и фильтрация теряется. Вот мой HTML код:

<form action="" method="get">
  <input type="checkbox" name="brand[]" value="iPhone">iPhone<br>
  <input type="checkbox" name="brand[]" value="iPad">iPad<br>
  <input type="checkbox" name="brand[]" value="Samsung">Samsung<br>
  <input type="checkbox" name="brand[]" value="Huawei">Huawei<br>

  <input type="submit" name="submit" value="Submit">
</form>

<?php include 'display_products.php';?>

Моя нумерация страниц сделана следующим образом:

for ($page=1;$page<=$number_of_pages;$page++) {
  if ($page == $page_active) {
    echo '<a class="page-number this-active" href="index.php?page=' . $page . '">' . $page . '</a> ';
  } else {
    echo '<a class="page-number" href="index.php?page=' . $page . '">' . $page . '</a> ';
  }
}

Чтобы применить фильтрацию, я использую оператор IF:

if (isset($_GET['brand'])) {
  $filter = implode('","',$_GET['brand']);
  $sql='SELECT * FROM products WHERE brand IN ("' . $filter . '") LIMIT ' . $this_page_first_result . ',' .  $results_per_page;
  $result = mysqli_query($conn, $sql);

  while($row = $result->fetch_assoc()) {
    echo '<div><h3>' . $row['title'] . '</h3><img src="' . $row['image'] . '"<h4>' . $row['price']. '</h4></div>';
  }
} //else display all products from the table of the database

Я предполагаю, что когда я go перехожу на следующую страницу, мои чекбоксы снимаются, этот $ _GET ['brand'] становится пустым и активируется оператор "else". Я пытался найти решения этой проблемы, но некоторые из них были неэффективными, а некоторые были слишком сложными для меня, чтобы понять (я новичок). Не могли бы вы объяснить в простых терминах, как сохранять флажки и как сохранять фильтрацию на всех страницах? Я видел такие идеи, как «использовать сессию» или «держать данные в URL», но я не могу понять, как это реализовать. Так что, если вы уточните c, я был бы очень благодарен. Большое спасибо!

1 Ответ

1 голос
/ 29 апреля 2020

Если бы вы использовали PHP для создания флажков brands (что имеет смысл, если есть много брендов, которые могут быть изменены в любое время, например, администратором), то, возможно, следующее может дать представление о том, как поддерживать статус checked для каждого флажка.

Ниже приведено приблизительное представление о том, как вы можете достичь sh поставленной цели - надеюсь, вам это поможет.

<?php
    function getParams(){
        return !empty( $_GET ) ? $_GET : [];
    }
    function buildQuery( $params=array() ){
        $tmp=array();
        foreach( $params as $param => $value ){
            if( is_array( $value ) ){
                foreach( $value as $field => $fieldvalue )$tmp[]=sprintf('%s[]=%s',$param,$fieldvalue);
            } else $tmp[]=sprintf('%s=%s',$param,$value);
        }
        return urldecode( implode( '&', $tmp ) );
    }

?>
<!DOCTYPE html>
<html lang='en'>
    <head>
        <meta charset='utf-8' />
        <title>Filtering & maintaining checkbox "checked" status</title>
        <style>
            fieldset{
                margin:1rem;
                padding:1rem;
                border:1px dotted gray;
            }
            #paging > a{
                padding:0.25rem;
                border:1px solid transparent;
            }
            #paging > a.active{
                border:1px solid red;
                background:yellow;
            }
        </style>
    </head>
    <body>
        <form method='get'>
            <fieldset>
                <?php
                    # an array of brands.. this could likely be from the database
                    $brands=['iPhone','iPad','Samsung','Huawei','Nokia','Sony','LG','Motorola','Blackberry','Vodafone','Alcatel','Razer','Google'];

                    # get either the current GET array or an empty array
                    $params=getParams();

                    # add the brands checkboxes
                    foreach( $brands as $brand ){
                        # maintain the checked status by checking if the current brand is in the `brand[]` querystring value
                        $checked=isset( $_GET['brand'] ) && in_array( $brand, $_GET['brand'] ) ? ' checked' : '';

                        # print the checkbox
                        printf('<input type="checkbox" name="brand[]" value="%1$s"%2$s>%1$s<br />', $brand, $checked );
                    }
                ?>
                <!-- a hidden field will ensure the page variable is set each time the form is submitted -->
                <input type='hidden' name='page' value='<?=isset( $_GET['page'] ) ? $_GET['page'] : 1;?>' />
                <input type='submit' />
            </fieldset>
            <fieldset id='paging'>
            <?php

                # some pseudo paging links... should be derived dynamically ~ this is just for demo
                for( $i=1; $i <= 10; $i++ ){

                    $params['page']=$i;
                    $active=isset( $_GET['page'] ) && intval( $_GET['page'] )==$i ? ' class="active"' : '';

                    printf('<a href="?%2$s" %3$s>[ %1$d ]</a>', $i, buildQuery( $params ), $active );
                }           
            ?>
            </fieldset>
        </form>
    </body>
</html>
...