Skip navigation
Обновлено
24 мая, 2024

При разработке многоязычных сайтов с помощью WPML Вам может понадобиться пользовательский переключатель языков. Узнайте, как это сделать с помощью простых PHP и CSS.

WPML позволяет Вам добавлять переключатели языков в меню, виджеты, нижние колонтитулы и на сайты с помощью редактора сайта (ранее известного как Полное редактирование сайта) с возможностью настройки и встроенными флагами. Но Вам может понадобиться что-то более особенное для Вашего сайта.

В этом уроке мы покажем, как добавить плавающий переключатель языков. Плавающий переключатель языков выглядит великолепно и облегчает Вашим клиентам просмотр сайта на их языке.

Сайт, использующий плавающий переключатель языков

Выполните следующие три основных шага:

  1. Добавьте PHP-код, который отображает переключатель языков.
  2. Создайте свой переключатель языков с помощью CSS
  3. Обновите настройки переключателя языков

Часть PHP

Первым шагом будет добавление PHP-кода, отвечающего за отображение переключателя языков на Вашей странице. Для этого Вы создаете функцию, которая добавляет контейнер div с переключателем языков внутри него. Мы можем использовать Действие wpml_add_language_selector отображает переключатель языков.

В этом примере мы хотим, чтобы новый переключатель языков отображался в нижнем колонтитуле, поэтому мы используем нашу новую функцию с собственным хуком WordPress wp_footer.

Полный код PHP будет выглядеть следующим образом.

Language switcher PHP
//WPML - Add a floating language switcher to the footer
 add_action('wp_footer', 'wpml_floating_language_switcher'); 
 
 function wpml_floating_language_switcher() { 
    echo '<div class="wpml-floating-language-switcher">';
        //PHP action to display the language switcher (see https://wpml.org/documentation/getting-started-guide/language-setup/language-switcher-options/#using-php-actions)
        do_action('wpml_add_language_selector');
    echo '</div>'; 
}

Вы можете скопировать и добавить его в файл functions.php Вашей (дочерней) темы.

Стайлинговая часть

С предыдущим кодом у нас уже есть новый переключатель языков, добавленный в нижний колонтитул нашего веб-сайта. Теперь пришло время настроить его так, чтобы он плавал в правом нижнем углу веб-сайта. Вы можете сделать это с помощью атрибута CSS position: fixed.

Выполните следующие действия, чтобы добавить код CSS:

  1. Перейдите в раздел WPML → Языки.
  2. Прокрутите вниз до раздела « Опции переключателя языков » и раскройте раздел » Дополнительные CSS «.

Также Вы можете добавить этот CSS-код, перейдя во Внешний вид → Настроить и нажав кнопку Additional CSS.

Следующий пример добавляет некоторые дополнительные настройки, такие как закругленные границы и box-shadow. Конечно, Вы можете настроить его по своему усмотрению.

Language Switcher Styling
/*Removing some default CSS from our language switcher*/
.wpml-floating-language-switcher .wpml-ls-statics-shortcode_actions {
  margin-bottom: 0;
}
 
.wpml-floating-language-switcher  .wpml-ls-statics-shortcode_actions a {
  background-color: transparent !important;
}
 
.wpml-floating-language-switcher .wpml-ls-legacy-list-horizontal a {
  padding: 5px;
}
 
 
/*Customize this if you want*/
.wpml-floating-language-switcher {
  position: fixed;
  bottom: 10px;
  right: 10px;
  background: #f8f8f8; /*background color*/
  border: 1px solid; /*border settings*/
  border-color: #eee; /*color of the border*/
  padding: 0px; /*padding of container*/
  border-radius: 6px; /*rounded border*/
  /*Box Shadow*/
  -webkit-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
  -moz-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
  box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
}

Часть «Настройки

Наконец, Вам нужно настроить некоторые параметры, чтобы переключатель языков отображал только флаги.

Выполните следующие действия:

  1. Перейдите в раздел WPML → Языки.
  2. Прокрутите страницу вниз до раздела Пользовательские переключатели языков и нажмите Включить.
  3. Нажмите пользовательскую кнопку Настроить.
  4. Для параметра Что включать в переключатель языков выберите Флаг и снимите флажки с остальных опций.
  5. Нажмите Сохранить.
Language switcher options
Отображение только флага в плавающем переключателе языков

Вот и все! Теперь у Вас на веб-сайте должен быть красивый переключатель языков:

Horizontal language switcher
Переключатель языков на фронтенде

Бонус: Вертикальный плавающий переключатель языков

Вместо этого Вы можете создать вертикальный переключатель языков, как на скриншоте ниже:

Vertical language switcher
Вертикальный переключатель языков

Для этого просто замените предыдущий CSS на следующий код:

Vertical Language Switcher CSS
/*Removing some default CSS our language switcher*/
.wpml-floating-language-switcher .wpml-ls-statics-shortcode_actions {
  margin-bottom: 0;
}
 
.wpml-floating-language-switcher  .wpml-ls-statics-shortcode_actions a {
  background-color: transparent !important;
}
 
.wpml-floating-language-switcher .wpml-ls-legacy-list-horizontal a {
  padding: 5px;
}
 
.wpml-floating-language-switcher .wpml-ls-item {
  display: block;
}
 
/*Customize this if you want*/
.wpml-floating-language-switcher {
  position: fixed;
  bottom: 20px;
  right: 0px;
  background: #f8f8f8; /*background color*/
  border: 1px solid; /*border settings*/
  border-color: #eee; /*color of the border*/
  padding: 0px; /*padding of container*/
  border-radius: 6px 0 0 6px; /*rounded border*/
  /*Box Shadow*/
  -webkit-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
  -moz-box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
  box-shadow: 2px 2px 5px 0px rgba(0,0,0,0.25);
  z-index: 999;
}