IntlDateFormatter::isLenient
datefmt_is_lenient
(PHP 5 >= 5.3.0, PHP 7, PHP 8, PECL intl >= 1.0.0)
IntlDateFormatter::isLenient -- datefmt_is_lenient — Obtém a leniência usada para o IntlDateFormatter
Descrição
Estilo orientado a objetos
Estilo procedural
Verifica se o interpretador é estrito ou leniente ao interpretar entradas que não correspondem exatamente ao modelo.
Parâmetros
formatter
-
O recurso do formatador.
Valor Retornado
true
se o interpretador for leniente, false
se for estrito. Por padrão o interpretador é leniente.
Exemplos
Example #1 Exemplo de datefmt_is_lenient()
<?php
$fmt = datefmt_create(
'en_US',
IntlDateFormatter::FULL,
IntlDateFormatter::FULL,
'America/Los_Angeles',
IntlDateFormatter::GREGORIAN,
'dd/MM/yyyy'
);
echo 'Leniência do formatador é : ';
if ($fmt->isLenient()) {
echo 'TRUE';
} else {
echo 'FALSE';
}
datefmt_parse($fmt, '35/13/1971');
echo "\nTentando interpretar '35/13/1971'.\nO resultado é: " . datefmt_parse($fmt, '35/13/1971');
if (intl_get_error_code() != 0) {
echo "\nMensagem de erro: " . intl_get_error_message();
echo "\nCódigo de erro: " . intl_get_error_code();
}
datefmt_set_lenient($fmt,false);
echo "\nAgora a leniência do formatador é: ";
if ($fmt->isLenient()) {
echo 'TRUE';
} else {
echo 'FALSE';
}
datefmt_parse($fmt, '35/13/1971');
echo "\nTentando interpretar '35/13/1971'.\nO resultado é: " . datefmt_parse($fmt, '35/13/1971');
if (intl_get_error_code() != 0) {
echo "\nMensagem de erro: " . intl_get_error_message();
echo "\nCódigo de erro: " . intl_get_error_code();
}
?>
Example #2 Exemplo OO
<?php
$fmt = new IntlDateFormatter(
'en_US',
IntlDateFormatter::FULL,
IntlDateFormatter::FULL,
'America/Los_Angeles',
IntlDateFormatter::GREGORIAN,
"dd/MM/yyyy"
);
echo "Leniência do formatador é : ";
if ($fmt->isLenient()) {
echo 'TRUE';
} else {
echo 'FALSE';
}
$fmt->parse('35/13/1971');
echo "\nTentando interpretar '35/13/1971'.\nO resultado é: " . $fmt->parse('35/13/1971');
if (intl_get_error_code() != 0){
echo "\nMensagem de erro: " . intl_get_error_message();
echo "\nCódigo de erro: " . intl_get_error_code();
}
$fmt->setLenient(FALSE);
echo "\nAgora a leniência do formatador é: ";
if ($fmt->isLenient()) {
echo 'TRUE';
} else {
echo 'FALSE';
}
$fmt->parse('35/13/1971');
echo "\nTentando interpretar '35/13/1971'.\nO resultado é: " . $fmt->parse('35/13/1971');
if (intl_get_error_code() != 0) {
echo "\nMensagem de erro: " . intl_get_error_message();
echo "\nCódigo de erro: " . intl_get_error_code();
}
?>
O exemplo acima produzirá:
Leniência do formatador é : TRUE Tentando interpretar '35/13/1971'. O resultado é: 66038400 Agora a leniência do formatador é: FALSE Tentando interpretar '35/13/1971'. O resultado é: Mensagem de erro: Date parsing failed: U_PARSE_ERROR Código de erro: 9
Veja Também
- datefmt_set_lenient() - Define a leniência do interpretador
- datefmt_create() - Cria um formatador de data