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]   

> Без описания
DlTA
Отправлено: 29 Сентября, 2016 - 15:17:09
Post Id



Постоянный участник


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


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




у меня функция чет возвращает, нужно проверить что там чет есть (какой то текст)

empty() - не походит !! только если я результат сохраню в переменную тогда можно но ((

есть какой то простой вариант?
 
 Top
Мелкий Супермодератор
Отправлено: 29 Сентября, 2016 - 15:27:18
Post Id



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


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


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




DlTA пишет:
empty() - не походит !! только если я результат сохраню в переменную тогда можно но ((

У вас сильно музейная версия PHP.

Приведите к булеву типу.


-----
PostgreSQL DBA
 
 Top
DlTA
Отправлено: 29 Сентября, 2016 - 15:35:13
Post Id



Постоянный участник


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


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




ем? 5,3. что есть

а для примера
$text = 'текст';
var_dump(empty($text)); // false
и
var_dump(empty('текст'));
// Parse error: syntax error, unexpected T_CONSTANT_ENCAPSED_STRING

function test(){
return 'тест';
}
var_dump(empty(test()));
//Fatal error: Can't use function return value in write context in

ну и?
(Добавление)
а это работает, хотя странно

$text = 'sdfg345';
var_dump((bool)$text);
// true
 
 Top
Мелкий Супермодератор
Отправлено: 29 Сентября, 2016 - 15:40:18
Post Id



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


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


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




Я и говорю сильно музейная. empty научили проверять результаты функций в уже музейном 5.5.0.

Повторюсь, вы всё ещё можете привести любой тип данных к булеву типу.Явно или неявно напрямую в сравнении.
http://php.net/manual/en/languag...ypes.boolean.php


-----
PostgreSQL DBA
 
 Top
DlTA
Отправлено: 29 Сентября, 2016 - 15:49:07
Post Id



Постоянный участник


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


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




тогда пойдет. +
 
 Top
Fart
Отправлено: 29 Сентября, 2016 - 17:27:33
Post Id



Посетитель


Покинул форум
Сообщений всего: 324
Дата рег-ции: Июль 2016  


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




только повнимательнее с empty, так как у нее есть особенность с пробелами, табом и новой строкой.
 
 Top
DlTA
Отправлено: 29 Сентября, 2016 - 17:30:23
Post Id



Постоянный участник


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


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




Fart пишет:
только повнимательнее с empty, так как у нее есть особенность с пробелами, табом и новой строкой.

я юзаю (bool), мне пока все равно.
 
 Top
Мелкий Супермодератор
Отправлено: 29 Сентября, 2016 - 17:32:45
Post Id



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


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


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




Fart, а поподробнее? Пробелы, табы и перевод строк будет !empty.
Аккуратнее надо с "0" который действительно empty.

Кстати, если из функции возвращается именно строка, то самое очевидное, что с ней можно сделать - сравнить с пустой строкой.


-----
PostgreSQL DBA
 
 Top
Fart
Отправлено: 29 Сентября, 2016 - 17:35:29
Post Id



Посетитель


Покинул форум
Сообщений всего: 324
Дата рег-ции: Июль 2016  


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




Уже которую сборку пхп 7+ пробел и таб и энтер пхп воспринимает как символы. Может че с пхп?
(Добавление)
Только trim спасает
(Добавление)
А не увидел в тексте ! - так то да. Я имел ввиду, что если есть некая ошибка и проверка только if(empty()) то сработает false

(Отредактировано автором: 29 Сентября, 2016 - 17:42:06)

 
 Top
Мелкий Супермодератор
Отправлено: 29 Сентября, 2016 - 22:06:56
Post Id



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


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


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




Ну это не особенность, а нормальное поведение. В строке же что-то есть. Особенность - это особая трактовка "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