Ce qui précède est correct si nous supposons que les tableaux ne peuvent contenir que des chaînes, mais que les tableaux peuvent également contenir d'autres tableaux. La fonction in_array () peut également accepter un tableau pour $ aiguille, donc strtolower ($ aiguille) ne fonctionnera pas si $ aiguille est un tableau et array_map ('strtolower', $ haystack) ne fonctionnera pas si $ haystack contient d'autres tableaux, mais entraînera un "avertissement PHP: strtolower () s'attend à ce que le paramètre 1 soit une chaîne, tableau donné".
Exemple:
$needle = array('p', 'H');
$haystack = array(array('p', 'H'), 'U');
J'ai donc créé une classe d'assistance avec les méthodes pertinentes, pour faire des vérifications in_array () sensibles à la casse et insensibles à la casse. J'utilise également mb_strtolower () au lieu de strtolower (), donc d'autres encodages peuvent être utilisés. Voici le code:
class StringHelper {
public static function toLower($string, $encoding = 'UTF-8')
{
return mb_strtolower($string, $encoding);
}
/**
* Digs into all levels of an array and converts all string values to lowercase
*/
public static function arrayToLower($array)
{
foreach ($array as &$value) {
switch (true) {
case is_string($value):
$value = self::toLower($value);
break;
case is_array($value):
$value = self::arrayToLower($value);
break;
}
}
return $array;
}
/**
* Works like the built-in PHP in_array() function — Checks if a value exists in an array, but
* gives the option to choose how the comparison is done - case-sensitive or case-insensitive
*/
public static function inArray($needle, $haystack, $case = 'case-sensitive', $strict = false)
{
switch ($case) {
default:
case 'case-sensitive':
case 'cs':
return in_array($needle, $haystack, $strict);
break;
case 'case-insensitive':
case 'ci':
if (is_array($needle)) {
return in_array(self::arrayToLower($needle), self::arrayToLower($haystack), $strict);
} else {
return in_array(self::toLower($needle), self::arrayToLower($haystack), $strict);
}
break;
}
}
}