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.SU

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


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

> Без описания
3d_killer
Отправлено: 14 Июля, 2014 - 19:22:32
Post Id



Участник


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


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




//Вывожу перед для проверки
echo($id_product." + ".$id_property." + ".$value_param);

//ВЫВОДИТ: 1300 + 5 + вапвап

if($value_param=='' || $value_param==NULL || $value_param==0)
{
//ПОПАДАЕМ СЮДА
}

как так получается?
 
My status
 Top
DelphinPRO
Отправлено: 14 Июля, 2014 - 19:52:28
Post Id



Активный участник


Покинул форум
Сообщений всего: 7187
Дата рег-ции: Февр. 2012  


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




потому что когда строка сравнивается с числом, она приводится к числу. любая строка, содержащая не цифровые символы будет приведена к нулю. Вот у вас и срабатывает последнее условие.

Вам, вероятно, нужно такое условие


(Добавление)
привдение типов срабатывает при нестрогом сравнении (!=, ==). При строгом сравнении (!==, ===) будет учитываться также и тип данных.


-----
Чем больше узнаю, тем больше я не знаю.
 
 Top
3d_killer
Отправлено: 14 Июля, 2014 - 20:04:11
Post Id



Участник


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


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




про empty забыл, благодарю
 
My status
 Top
Мелкий Супермодератор
Отправлено: 14 Июля, 2014 - 20:05:32
Post Id



Активный участник


Покинул форум
Сообщений всего: 11926
Дата рег-ции: Июль 2009  
Откуда: Россия, Санкт-Петербург


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




DelphinPRO пишет:
любая строка, содержащая не цифровые символы будет приведена к нулю.

Уточню:
Если строка начинается с цифр - то будет интерпретирована как число до первого встретившегося нецифрового значения.
Если начинается не с цифры - то 0.


-----
PostgreSQL DBA
 
 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