Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Передача из одного php файла в другой методом GET

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
andrevbnk
Отправлено: 30 Апреля, 2018 - 11:54:18
Post Id



Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Апр. 2018  
Откуда: Украина


Помог: 0 раз(а)




Здравствуйте, я изучаю php не так давно и у меня возникли трудности,хотел сделать сортировку на сайте методом GET

-------------------------------- -------------------------------- -----index.php------------------ -------------------------------- ------------
PHP:
скопировать код в буфер обмена
  1. <?PHP
  2. $sorting = $_GET["sort"];
  3.   switch ($sorting) {
  4.     case 'cost-asc':
  5.     $sorting = 'cost ASC';
  6.     break;
  7.     case 'cost-desc':
  8.     $sorting = 'cost DESC';
  9.     break;
  10.  
  11.     case 'popular':
  12.     $sorting = 'ord ASC';
  13.     break;
  14.     case 'news':
  15.     $sorting = 'id DESC';
  16.     break;
  17.  
  18.     case 'brand':
  19.     $sorting = 'name ASC';
  20.     break;
  21.  
  22.     default:
  23.     $sorting= 'id ASC';
  24.       break;
  25.   }
  26. ?>

CODE (html):
скопировать код в буфер обмена
  1.  
  2.   <li class="sort"><a href="index.php?sort=cost-asc" id="tab1">Возростание</a></li>
  3.   <li class="sort"><a href="index.php?sort=cost-desc" id="tab1">Убыванию</a></li>
  4.   <li class="sort"><a href="index.php?sort=popular" id="tab1">Популярные</a></li>
  5.   <li class="sort"><a href="index.php?sort=news" id="tab1" >Новинки</a></li>
  6.   <li class="sort"><a href="index.php?sort=brand" id="tab1" >От А до Я </a></li>

-------------------------------- -------------------------------- -------------------------------- -------------------------------- ----------------

И есть function.php в котором есть функция loadGoods
PHP:
скопировать код в буфер обмена
  1. function loadGoods()
  2. {
  3.     $conn = connect();
  4.     $sql1 = "SELECT * FROM goods ORDER BY ".$sorting." ";
  5.     $result = mysqli_query($conn, $sql1);
  6.     if (mysqli_num_rows($result) > 0) {
  7.         $out = array();
  8.         while($row = mysqli_fetch_assoc($result)) {
  9.             $out[] = $row;    
  10.         }
  11.        echo json_encode($out);
  12.     }
  13.     else {
  14.         echo "0";
  15.     }
  16.     mysqli_close($conn);
  17. }



Как мне передать $sorting в эту функцию?
Если не трудно,скиньте рабочий код.
 
 Top
Строитель Модератор
Отправлено: 30 Апреля, 2018 - 12:17:45
Post Id



Участник


Покинул форум
Сообщений всего: 1580
Дата рег-ции: Февр. 2014  
Откуда: Украина


Помог: 73 раз(а)




andrevbnk пишет:
Как мне передать $sorting в эту функцию?
Так и передавайте, ввиде аргумента:
Спойлер (Отобразить)
Ну и вызов функции после свитча нужно написать:
Спойлер (Отобразить)
 
 Top
andrevbnk
Отправлено: 30 Апреля, 2018 - 21:01:45
Post Id



Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Апр. 2018  
Откуда: Украина


Помог: 0 раз(а)




А не через аргумент нельзя? Не вызывая функцию

"Ну и вызов функции после свитча нужно написать:" - мне не нужно вызывать эту функцию ибо loadGoods вызывается в JS файле

(Отредактировано автором: 30 Апреля, 2018 - 21:06:55)

 
 Top
Строитель Модератор
Отправлено: 30 Апреля, 2018 - 22:17:48
Post Id



Участник


Покинул форум
Сообщений всего: 1580
Дата рег-ции: Февр. 2014  
Откуда: Украина


Помог: 73 раз(а)




andrevbnk пишет:
А не через аргумент нельзя?
Можно -- объявить переменную в теле функции глобальной, например так:
Спойлер (Отобразить)
Или так:
Спойлер (Отобразить)
Но использование глобальных переменных это плохая практика. Если ничего не мешает передать значение аргументом, то лучше обойтись без глобальных переменных.
 
 Top
andrevbnk
Отправлено: 01 Мая, 2018 - 18:23:32
Post Id



Новичок


Покинул форум
Сообщений всего: 3
Дата рег-ции: Апр. 2018  
Откуда: Украина


Помог: 0 раз(а)




Спасибо что ответили на мой вопрос , но проблему я решил путём открытия сессии
PHP:
скопировать код в буфер обмена
  1.  
  2.  
  3. $sorting = $_GET["sort"];
  4.  
  5.   switch ($sorting) {
  6.     case 'cost-asc':
  7.     $sorting = 'cost ASC';
  8.     break;
  9.    
  10.     case 'cost-desc':
  11.     $sorting = 'cost DESC';
  12.     break;
  13.        
  14.  
  15.     case 'popular':
  16.     $sorting = 'ord ASC';
  17.     break;
  18.  
  19.     case 'news':
  20.     $sorting = 'id DESC';
  21.     break;
  22.  
  23.  
  24.     case 'brand':
  25.     $sorting = 'name ASC';
  26.     break;
  27.  
  28.     default:
  29.     $sorting = 'id ASC';
  30.     break;
  31.   }
  32.  
  33. $_SESSION['sort'] = $sorting;




PHP:
скопировать код в буфер обмена
  1. function loadGoods()
  2. {
  3.     session_start();
  4.  
  5.     $sorting = $_SESSION['sort'];
  6.        
  7.     $conn = connect();
  8.     $sql1 = "SELECT * FROM goods ORDER BY ".$sorting." ";
  9.     $result = mysqli_query($conn, $sql1);
  10.  
  11.     if (mysqli_num_rows($result) > 0) {
  12.         $out = array();
  13.         while($row = mysqli_fetch_assoc($result)) {
  14.             $out[] = $row;            
  15.         }
  16.  
  17.        echo json_encode($out);
  18.     }
  19.     else {
  20.         echo "0";
  21.     }
  22.  
  23.     mysqli_close($conn);
  24. }
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Вопросы новичков »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB