sanitize_html_class() — преобразует строку, делая её пригодной для использования в качестве HTML-класса

Функция фильтрует строку по регулярному выражению /[^A-Za-z0-9_-]/, удаляя все неподходящие символы и пробелы, да, это означает, что русские буквы будут также удалены.

sanitize_html_class( $class, $fallback = '' );

$class
(строка) (обязательное) — строка, которая будет использовать в качестве класса.

$fallback
(строка) (необязательное) — в этом параметре определяется, что должна возвращать функция в том случае, если результатом преобразования является пустая строка.

Примеры

Не совсем корректный для русскоязычных блогов пример с заголовком:

echo '<div class="' . sanitize_html_class( $post->post_title ) . '">';

Обратите внимание, если заголовок вашего поста полностью русский, то скорее всего от него ничего не останется.

В оригинальном WordPress Codex они ещё дополнительно пропускают атрибут класса через функцию esc_attr() — не совсем понятно, для чего это, ведь в классе и так уже не остается запрещенных символов, если только их может содержать переменная $fallback, например:

echo '<div class="' . esc_attr( sanitize_html_class( $title, 'h&m' ) ) . '">';

То есть, если в этом случае функция вернет h&m, то класс будет h&amp;m.

Источник: misha.blog

Миша Рудрастых

Путешествует по миру и рассказывает всем о WordPress лично, у себя в блогах и на курсах в Санкт-Петербурге. Умеет просто объяснять сложные вещи, делает это красиво. Организовывает неплохие WordCamp's, но совсем не умеет слушать чужие доклады.

Добавить комментарий

%d такие блоггеры, как: