Блог
впервые я сталкиваюсь с проблемой, которую не могу объяснить. Я создаю простой цикл wordpress для галереи, но, я не знаю почему, цикл изменяет мой HTML-код внутри цикла.
Сначала это то, что я написал :
query_posts('posts_per_page=9'); if ( have_posts() ) : while ( have_posts() ) : the_post(); ?> $post_image_id = get_post_thumbnail_id($post_to_use->ID); if ($post_image_id) < $thumbnail = wp_get_attachment_image_src( $post_image_id, 'large', false); if ($thumbnail) (string)$thumbnail = $thumbnail[0]; > else < $thumbnail = './assets/no-picture.jpg'; > ?> class > <a href data-toggle class > <img src class alt > <div class > <div class > <div> <h2>h2> <h6 class='wide-space'>h6> <i class >i> div> div> div> a> article>
Но когда он запускается онлайн, код внутри цикла становится таким :
class > <a href data-toggle class > <img src class alt > a> <div class > <a href data-toggle class >a> <div class > <a href data-toggle class > a> <div> <a href data-toggle class > <h2>Lessines, Terre de développementh2> a> <h6 class > <a href data-toggle class >a> <ul class > <a href data-toggle class >a> <li><a href data-toggle class >a> <a href rel >Corporatea> li> ul> h6> <i class >i> div> div> div> article>
Есть ли кто — нибудь , кто мог бы помочь мне в этом ? Я никогда не видел этого раньше, и я часто использую этот вид цикла.
Комментарии:
1. Небольшое примечание Вам действительно не нужно, if ( have_posts() ) : за которым while ( have_posts() ) : следует a, как будто нет сообщений, while все равно ничего не сделает
2. Убедитесь, что у вас нет где-то кэшированного старого кода, поскольку я не понимаю, как этот код мог бы выдать такой результат
Вордпресс редактирует (чистит) код. Что делать?
Я и раньше сталкивался с тем, что Вордпресс по-своему воспринимает код в контентной части. Он его интерпретирует по-особому, по-вордпрессовски. Причём не всегда предсказуемо.
Как удалить тег «p» в WordPress
WordPress автоматически форматирует параграфы тегами , используя фильтр wpautop .
Кому-то это доставляет массу неудобств. Правда я не пойму каких. Как можно вообще форматировать текст, разбивая его на абзацы, не используя специально предназначенный для этого тег? (Если кто-то считает по-другому, пожалуйста — это можно обсудить в комментариях).
Плагин wpautop control
Так вот, чтобы облегчить жизнь таким пользователям, bigsmoke, написал специальный плагин wpautop control (WordPress Auto Paragraph, наверное он так расшифровывается).
После установки плагина, в настройках плагина (Параметры→wpautop control options) простым нажатием флажка можно отключить все теги p.
Normally, WordPress filters your posts’ content using the wpautop filter. Roughly, what this filter does is that it replaces newlines and empty lines with
or . The setting below lets you turn this filter on or off. (You can later override it on a post-by-post basis by setting the wpautop custom field to ‘true’ or ‘false’.)
wpautop filter on by default? | yes (WordPress’ default behaviour) no (turn of WordPress’ auto-formatting, except for selected posts) |
---|
Но этот плагин тоже не всегда помогает.
Редактирование файла functions.php
Если не хотите устанавливать плагин, то можно добавить в файл functions.php вашей темы одну строчку (можно в конце файла).
remove_filter('the_content', 'wpautop');
Но я столкнулся с другой проблемой.
Как избежать от автоматического форматирования текста в WordPress
Сейчас я объясню с чего всё началось. Мне нужно было на сайте клиента отформатировать страницу с наградами и их описанием. Сайт работает под управлением ВордПресс.
Чтобы отформатировать (сделать отступы) с помощью перевода строк, да и еще на 3-х языках, у меня ушел целый час времени! Почему? Потому что Вордпресс сам редактирует код. Для решения данной проблемы, добавлять стили к картинке я не хотел, потому что клиент не сможет его применить с помощью стандартного визуального редактора.
Из-за того что текста мало, дипломы наползали друг на друга. И приходилось добавлять . Но они жили не так долго: при переключении из визуального режима в HTML, Вордпресс их склеивал и оставлял ровно столько, сколько хотел. В результате чего бесследно уничтожая всю проделанную работу.
То есть форматирование отступами с помощью перевода строк не помогало. На выходе все было отформатировано: перевод строк сокращен до одного. Я читал, что некоторые даже пытались отключить визуальный редактор (полезно прочесть ветвь обсуждение « WordPress чистит код. Как бороться » на форуме русский ВордПресс), но это тоже было бесполезно — значит Вордпрес пропускает текст через специальный фильтр.
С этим мириться никак было нельзя и пришлось искать в нете возможные пути решения данной проблемы.
В первую очередь пришла мысль воспользоваться одним из двух вариантов:
- Добавить текст, чтобы он автоматически заполнял свободное пространство.
- Обрамлять каждый блок (текст + картинка) отдельным дивом, который не будут наползать друг на друга.
Как оказалось, в моем примере, каждый диплом будет отделяться от других наград годом вручения, который находится в теге h3.
Ну, хорошо, я прописал тегу h3 свойство clear , с параметром both , чтобы исключить обтекание с правого и левого края.
Но как задать отступ снизу у картинки сертификата? Ведь в Вордпрессе верстка делится на шаблон для рубрик и шаблон одной записи. То есть изменние коснется всего сайта. И у всех картинок появится отступ.
Нужно каким-то образом уникализировать эти картинки, например поместить их, да и не только их, а лучше сразу весь контент страницы «Награды» в отдельный див awards , через который можно легко обратиться к картинкам. А в CSS прописать им отступы вот так:
Но это еще не все. Я нашел супер мега-плагин TinyMCE Advanced. У него в настройках можно поставить флажок, чтобы Вордпресс не удалял теги p и br , когда сохряняет и отображает их в HTML-редакторе.
Я его установил на свой блог. Но, к сожалению, он тоже не без недостатков. Этот плагин не позволит отобразить тег так каким мы его видим в HTML. То есть, он убивает угловые скобки, которые шифруются кодами < и > , левая и правая соответственно. Но, за то в режиме кода, вы можете видеть родной HTML со всеми тегами!
Кстати очень странно, но у меня этот плагин стал полезным лишь, когла я убрал флажок (как отмечено желтым маркером).
В WordPress в настройках можно отключить функцию автоматического исправления некорректного XHTML-кода.
Настройки → Написание → «WordPress должен исправлять некорректный XHTML-код автоматически»
Вот так, преодолевая какое-то препятствие, нахожу что-то новое и полезное для себя. А потом — охотно делюсь своими находками в своем блоге.
При создании сайта на WordPress часто используют темы, содержащие страницы, созданные в конструкторе Elementor. Чтобы
В Elementor встроена библиотека шрифтовых иконок Font Awesome, но зачастую этого недостаточно для полноценной
Кэширование обеспечивает минимальное время загрузки сайта, необходимое для улучшения поисковой оптимизации и увеличения конверсий.
В настройках можно отключить форматирование кода.
Настройки-написание
вверху снимаем галочку возле WordPress должен исправлять некорректный XHTML-код автоматически.
Сохраняемся.
Есть
У меня тоже есть причем на голой CMS уже была и до сих пор никуда не исчезла. Видимо это у вас какой-то плагин или перепиленная версия WP
В новых версиях WordPress пользователи столкнулись с некоторыми «приколами» визуального редактора записей, и одна из них — это то, что автоматически удаляются пустые переносы строки в записи. Как это исправить? Если загуглить «WordPress убирает пустые переносы строки» на первом месте будет несколько десятков форумов, где тру-верстальщики, убеждают, что «нельзя пользоваться визуальным редактором и ставить пустые переносы с помощью
! Это невалидно! Поэтому редактор и выпиливает эту ерунду. Вот решение: 1. Установите плагин «TinyMCE Advanced».
2. В его настройках поставьте галочку «Остановить удаление тегов
и
при сохранении и показать их в текстовом редакторе». Проверяйте, что получится на уже опубликованной странице. Скорее всего, строки будет съедать по-прежнему. Значит, у вас стоят новые шорткоды. Тогда 1. Найдите файл /wp-content/plugins/shortcodes-pro/inc/class-shortcodespro-base.php
2. И в нём этот фрагмент кода function remove_empty_elements( $content ) return str_replace( array( ' ', ' ', '
' ), '', $content );
> 3. Удалите вот это ‘
’ и запятую перед ним. Всё! Пользуйтесь, как в привычном ворде.
«Как можно вообще форматировать текст, разбивая его на абзацы, не используя специально предназначенный для этого тег?» Вопрос не в том, что нужно форматировать абзацы без , а в том, что wordpress пихает эти абзацы куда ему захочется. В результате, если использована верстка дивами ограниченой ширины с float, аккуратная «таблица» (как здесь, в плагине входа через социалку) разворачивается по вертикали в огромное полотенце.
Вот как раз столкнулась с проблемой , когда вордпресс ставил свои теги p.
Мне нужно было в одном посте вставить инлайновый js . И вот его вордпресс и пытался отформатировать, вставляя в коде ненужные теги p
Там нельзя отключить форматирование кода! В «Настройках-написание» даже нет такого пункта меню «Форматирование». Версия Вордпресса у меня стоит последняя — 4.8. И нет там никакой галочки! И очень жаль что нет. Мне данный функционал очень нужен. Ну по любому это какой-то плагин стоит. Что у вас там за плагин такой стоит и дополните в свою статью, пожалуйста!
В первые кстати вижу чтобы администратор редактировал комментарии своих пользователей) Вот это прикол))
Стас, мой блог — это не официальная компания, которая раскручивает свой бренд. Это личный блог, поэтому правила здесь устанавливаю я. Например, здесь не принято писать капслоком. Тем не менее, конструктивная критика приветствуется, но не должна быть высказана в слегка хамоватом тоне. Здесь все помогают друг другу, каждый по мере своих возможностей и, как вы заметили, совершенно бесплатно. Безвозмездно, то есть даром
Выясните, пожалуйста, что у вас за плагин такой стоит и дополните свою статью! Чтобы не вводить людей в заблуждение ложной информацией, как и многие другие комментаторы здесь, у которых есть эта штука, но никто походу не понимает откуда она.
Существует несколько способов ограничить этот его функционал, однако полностью отключить фильтрацию кода невозможно. Можно отключить визуальный редактор для отдельных записей, категорий или шаблонов страниц. Для отключения визуального редактора TinyMCE на определённых страницах или постах, нужно добавить в файл functions.php вашего активного WordPress шаблона следующий код: function disable_visual_editor($can)
global $post; /*
* Отключить визуальный редактор WordPress на странице с определённым ID (в нашем примере с/> */
if ($post->ID == 15) return false;
> /*
* Скрыть визуальный редактор TinyMCE на страницах с ID 16, 25 и 30 (для случаев, когда нужно убрать редактор сразу для нескольких страниц)
*/
$disabled_IDs = array (16, 25, 30);
if (in_array($post->ID, $disabled_IDs)) return false;
> /*
* Отключить визуальный редактор ВордПресс на страницах с определённым шаблоном (. ВНИМАНИЕ. нужно указывать не название шаблона поста или страницы, а имя файла этого шаблона, например my_page_template.php)
*/
$page_template = get_post_meta($post->ID, '_wp_page_template', true);
if ($page_template == 'my_page_template.php') return false;
> return $can;
> add_filter('user_can_richedit', 'disable_visual_editor');
Имея доступ к объекту $post , можно использовать также и другие его свойства (post_title, post_name и др.), чтобы убрать визуальный редактор для страниц с определённым заголовком, URL и т.д. А с использованием таких функций как get_the_category($post->ID); или wp_get_current_user(); вы можете убрать визуальный редактор для определённой категории или же пользователя (группы пользователей, определённой роли и т. п.)