(PHP 4, PHP 5, PHP 7)
empty — Détermine si une variable est vide
Détermine si une variable est considérée comme vide.
Une variable est considérée comme vide si elle n'existe pas,
ou si sa valeur équivaut à FALSE
. La fonction empty()
ne génère pas d'alerte si la variable n'existe pas.
var
Variable à vérifier.
Note:
Avant PHP 5.5, la fonction empty() ne supportait que les variables ; tout autre type retournait une erreur d'analyse. En d'autres termes, ce qui suit ne fonctionnait pas : empty(trim($name)). A la place, utilisez trim($name) == false.
Aucune alerte n'est générée si la variable n'existe pas. Cela signifie que empty() est strictement équivalent à !isset($var) || $var == false.
Retourne FALSE
si var
existe et est non-vide,
et dont la valeur n'est pas zéro.
Ce qui suit est considéré comme étant vide :
NULL
FALSE
Version | Description |
---|---|
5.5.0 |
empty() supporte maintenant les expressions, et plus seulement les variables. |
5.4.0 |
La vérification des positions non-numériques
d'une chaîne retourne maintenant |
Exemple #1 Une comparaison simple empty() / isset().
<?php
$var = 0;
// Evalué à vrai car $var est vide
if (empty($var)) {
echo '$var vaut soit 0, vide, ou pas définie du tout';
}
// Evalué à vrai car $var est défini
if (isset($var)) {
echo '$var est définie même si elle est vide';
}
?>
Exemple #2 empty() sur des positions dans une chaîne
PHP 5.4 modifie le comportement de la fonction empty() lors de l'utilisation de positions dans une chaîne.
<?php
$expected_array_got_string = 'somestring';
var_dump(empty($expected_array_got_string['some_key']));
var_dump(empty($expected_array_got_string[0]));
var_dump(empty($expected_array_got_string['0']));
var_dump(empty($expected_array_got_string[0.5]));
var_dump(empty($expected_array_got_string['0.5']));
var_dump(empty($expected_array_got_string['0 Mostel']));
?>
Résultat de l'exemple ci-dessus en PHP 5.3 :
bool(false) bool(false) bool(false) bool(false) bool(false) bool(false)
Résultat de l'exemple ci-dessus en PHP 5.4 :
bool(true) bool(false) bool(false) bool(false) bool(true) bool(true)
Note: Comme ceci est une structure du langage, et non pas une fonction, il n'est pas possible de l'appeler avec les fonctions variables.
Note:
Lors de l'utilisation de cette fonction sur des propriétés d'objet inaccessibles, la méthode magique __isset() sera appelée, si elle existe.