_n()

Владислав Белецкий
Владислав Белецкий .
Категория:
Комментариев: 0

Функция переводит и возвращает строку, в которой содержится число, и в зависимости от значения числа строка будет переведена в соответствующей форме единственного или множественно числа. Например 1 зомби, 2 зомби, 5 зомби… Шутка! Например 1 остров, 2 острова, 5 островов.

_n( $single, $plural, $number, $domain = 'default' )

Параметры

$single
(строка) Значение строки в единственном числе (для английского языка).
$plural
(строка) Значение строки во множественном числе (для английского языка).
$number
(целое число) Число, которое будет определять использование формы единственного или множественного числа.
$domain
(строка) Идентификатор перевода. Задаётся в виде строки, не передавайте в этот параметр переменных.

Примеры

Простой пример, чтобы понять, как вообще работает функция:

$amount = '4';
echo _n( 'One', 'Many', $amount, 'truemisha' );
// если $amount не равен 1 (0 кстати тоже прокатит), то выведет перевод для 'Many' (много)
// если $amount равен 1, то выведет перевод слова 'One' (один)

Подобные примеры вы нечасто найдете в темах и плагинах WordPress, обычно в таких случаях всегда используется php-функция sprintf().

$amount = '4';
 
$products = sprintf( _n( '1 product', '%d products', $amount, 'truemisha' ), $amount );
 
echo $products; // выведет "4 товара"

Ничего сложного, главное запомните одну вещь — никаких вычислений внутри sprintf()!

Кстати, если не указывать последний параметр функции, $domain, то для перевода будут использоваться стандартные языковые файлы WordPress (которые задействованы в переводе движка). Понятное дело, что перевода ваших строк там может и не быть. К примеру:

echo sprintf( _n( '1 comment approved', '%d comments approved', $approved ), $approved );
Подписаться
Уведомить о
guest
0 комментариев
Межтекстовые Отзывы
Посмотреть все комментарии