Меню

Php вывести контент страницы

the_content() – выводит контент страницы или записи

Функция the_content() выводит содержимое текущего поста (записи, страницы или произвольного типа поста) в цикле.

Функция для использования внутри цикла WordPress. Если вам нужен контент не текущей, а определённой записи или страницы, то взляните на get_the_content().

Выводит полностью весь пост, если задействована на страницах:

  • записей (например в файле single.php ),
  • страниц (например в файле page.php ),
  • произвольных типов постов (например это может быть файл single- <тип_поста>).

Выводит только часть контента поста, которая находится до тега на следующих типах страниц:

  • рубрики category.php ,
  • метки tag.php ,
  • таксономии taxonomy.php .
  • поиск search.php ,
  • архивы archive.php ,

По поводу упомянутых файлов – не обязательно для отображения определённого типа страницы может задействоваться именно указанный файл, например для рубрик может использоваться и archive.php , и index.php , для лучшего понимания рекомендую посмотреть видеоурок про иерархию шаблонов.

Параметры

Функция ничего не возвращает.

Пример 1. Выводим контент, изменив при этом текст ссылки «Далее»

По сути в данной ситуации всё, что нам нужно сделать, это задать первый параметр функции.

В этот параметр вы даже можете передать заголовок записи/страницы функцией the_title(), вот так примерно:

Пример 2. Включаем или отключаем обрезку по тегу

Если функция the_content() работает не совсем так, как нам хотелось бы, например обрезает контент по тегу , когда мы этого не хотим, или наоборот, не обрезает, когда хотим, то мы можем изменить это поведение функции при помощи глобальной переменной $more .

Для этого нам нужно:

  1. Определить глобальную переменную перед циклом global $more;
  2. Затем, уже непосредственно перед функцией the_content() , присвоить ей значение 0 (отображать анонсы) или 1 (отображать целиком весь пост), например $more = 0; .

Подробнее про основной цикл читайте / смотрите видеоурок здесь.

Второй пример — возможно вы уже читали пост про прилепленные записи. Так вот, используя условный тег is_sticky(), мы можем сделать так, чтобы для прилепленных записей контент отображался целиком, а для всех остальных записей выводились только анонсы.

the_content — изменяем содержимое поста перед выводом

Как я уже говорил, этот фильтр очень популярен и используется во многих плагинах. Его даже используют для добавления ссылок на похожие записи в конце поста.

Очень рекомендую обратить на этот фильтр внимание, так как благодаря ему WordPress делает с контентом страницы очень много всего перед выводом, например:

  1. Ререндерит блоки, благодаря чему мы можем изменять вывод блоков, как в этом примере.
  2. Производит автоматическую замену кавычек и других символов функцией wptexturize().
  3. Преобразует символы типо 🙂 в смайлики.
  4. Применяет функцию wpautop() для расстановки HTML-тегов абзацев

и переносов строки
.
Убеждается, что в контенте нет шорткодов, обёрнутых в

, если да, то удаляет этот тег.
Затем оборачивает вложения в тег

.

  • Фильтрует такие теги как и , чтобы добавить к ним атрибуты srcset , sizes и loading , которые могли не существовать на момент создания поста.
  • Если сайт использует https:// , то заменяет все http:// на https:// в контенте.
  • Применяет шорткоды функцией do_shortcode().
  • Ещё применяется функция capital_P_dangit(), которая исправляет неправильное написание WordPress (например, когда пишут с маленькой буквы: WordPress или wordpress).
  • Если для вывода контента вы используете например функцию get_the_content(), то ничего из этого применяться не будет!

    Впервые познакомился с WordPress в 2009 году. Организатор и спикер на конференциях WordCamp. Преподаватель в школе Нетология.

    Если вам нужна помощь с сайтом или разработка с нуля на WordPress / WooCommerce — пишите. Я и моя команда будем рады вам помочь!

    Источник

    file_get_contents

    (PHP 4 >= 4.3.0, PHP 5, PHP 7, PHP 8)

    file_get_contents — Читает содержимое файла в строку

    Описание

    Данная функция похожа на функцию file() с той лишь разницей, что file_get_contents() возвращает содержимое файла в строке, начиная с указанного смещения offset и до length байт. В случае неудачи, file_get_contents() вернёт false .

    Использование функции file_get_contents() наиболее предпочтительно в случае необходимости получить содержимое файла целиком, поскольку для улучшения производительности функция использует технику отображения файла в память (memory mapping), если она поддерживается вашей операционной системой.

    Если вы открываете URI, содержащий спецсимволы, такие как пробел, вам нужно закодировать URI при помощи urlencode() .

    Список параметров

    Имя читаемого файла.

    Можно использовать константу FILE_USE_INCLUDE_PATH для поиска файла в include path. Только помните, что если вы используете строгую типизацию, то так сделать не получится, поскольку FILE_USE_INCLUDE_PATH имеет тип int . В таком случае используйте true .

    Корректный ресурс контекста, созданный с помощью функции stream_context_create() . Если в использовании особого контекста нет необходимости, можно пропустить этот параметр передав в него значение null .

    Смещение, с которого начнётся чтение оригинального потока. Отрицательное значение смещения будет отсчитываться с конца потока.

    Поиск смещения ( offset ) не поддерживается при работе с удалёнными файлами. Попытка поиска смещения на нелокальных файлах может работать при небольших смещениях, но результат будет непредсказуемым, так как функция работает на буферизованном потоке.

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

    Возвращаемые значения

    Функция возвращает прочтённые данные или false в случае возникновения ошибки.

    Эта функция может возвращать как логическое значение false , так и значение не типа boolean, которое приводится к false . За более подробной информацией обратитесь к разделу Булев тип. Используйте оператор === для проверки значения, возвращаемого этой функцией.

    Ошибки

    Будет сгенерирована ошибка уровня E_WARNING в случаях, если не удастся найти filename , задан length меньше нуля, или поиск по смещению offset в потоке завершится неудачно.

    Когда file_get_contents() вызывается в каталоге, в Windows ошибка генерируется E_WARNING , а с PHP 7.4 также в других операционных системах.

    Список изменений

    Версия Описание
    7.1.0 Добавлена поддержка отрицательных значений offset .

    Примеры

    Пример #1 Получить и вывести исходный код домашней страницы сайта

    Пример #2 Поиск файлов в include_path

    Пример #3 Чтение секции файла

    Результатом выполнения данного примера будет что-то подобное:

    Пример #4 Использование потоковых контекстов

    // Создаём поток
    $opts = array(
    ‘http’ =>array(
    ‘method’ => «GET» ,
    ‘header’ => «Accept-language: en\r\n» .
    «Cookie: foo=bar\r\n»
    )
    );

    $context = stream_context_create ( $opts );

    // Открываем файл с помощью установленных выше HTTP-заголовков
    $file = file_get_contents ( ‘http://www.example.com/’ , false , $context );
    ?>

    Примечания

    Замечание: Эта функция безопасна для обработки данных в двоичной форме.

    Для этой функции вы можете использовать URL в качестве имени файла, если была включена опция fopen wrappers. Смотрите более подробную информацию об определении имени файла в описании функции fopen() . Смотрите также список поддерживаемых обёрток URL, их возможности, замечания по использованию и список предопределённых констант в разделе Поддерживаемые протоколы и обёртки.

    При использовании SSL, Microsoft IIS нарушает протокол, закрывая соединение без отправки индикатора close_notify . PHP сообщит об этом как «SSL: Fatal Protocol Error» в тот момент, когда вы достигнете конца данных. Чтобы обойти это, вы должны установить error_reporting на уровень, исключающий E_WARNING. PHP умеет определять, что на стороне сервера находится проблемный IIS при открытии потока с помощью обёртки https:// и не выводит предупреждение. Если вы используете fsockopen() для создания ssl:// сокета, вы сами отвечаете за определение и подавление этого предупреждения.

    Смотрите также

    • file() — Читает содержимое файла и помещает его в массив
    • fgets() — Читает строку из файла
    • fread() — Бинарно-безопасное чтение файла
    • readfile() — Выводит файл
    • file_put_contents() — Пишет данные в файл
    • stream_get_contents() — Читает оставшуюся часть потока в строку
    • stream_context_create() — Создаёт контекст потока
    • $http_response_header

    Источник

    the_content() — выводит контент поста

    Функция возвращает содержимое текущего поста. Работает только в цикле .

    Выводит полностью весь пост, если задействована на страницах:

    • записей single.php ,
    • страниц page.php ,
    • произвольных типов постов single- <тип_поста>.

    Выводит только часть контента поста, которая находится до тега на следующих типах страниц:

    • рубрики category.php ,
    • метки tag.php ,
    • архивы archive.php ,
    • таксономии taxonomy.php .

    Что делать, если у вас выводится полный текст поста, а вы хотите выводить анонсы со ссылкой «Далее»?

    Всё, что нам потребуется сделать, это:

      Непосредственно перед циклом определить глобальную переменную $more .

    Читайте также описание функции the_title().

    Второй пример — возможно вы уже читали пост про прилепленные записи. Так вот, используя условный тег is_sticky(), мы можем сделать так, чтобы для прилепленных записей контент отображался целиком, а для всех остальных записей выводились только анонсы.

    Как вывести содержимое конкретного поста, зная его ID?

    В отличие от функций get_the_title() и get_permalink() функции для вывода контента поста не имеют параметра с ID поста, так что нам не удастся получить или вывести контент какого-либо определенного поста вне цикла этим способом.

    Другой способ — функция get_post().

    В этом примере (который выше) у нас выведется неотфильтрованный контент — в том самом виде, в котором он находится в базе данных. Так как очень многие плагины в WordPress применяют свои фильтры к контенту постов, то такой способ хорош, если вы хотите обойти этот фильтр.

    Если фильтр the_content в данном случае вам нужен, тогда наш пример изменится следующим образом:

    Фильтры

    the_content_more_link — позволяет изменить кнопку «Далее»

    Как же так, ведь текст кнопки «Далее» можно указать в первом параметре функции the_content() ? Дело в том, что там вы можете указать только текст ссылки, а фильтр the_content_more_link позволяет полностью изменить её HTML код.

    В качестве примера добавим к ссылке «Далее» HTML-атрибут target=»_blank» .

    the_content — изменяем содержимое поста перед выводом

    Как я уже говорил, этот фильтр очень популярен и используется во многих плагинах. Его даже используют для добавления ссылок на похожие записи в конце поста.

    Источник

    the_content() WP 0.71

    Выводит контент текущего поста (записи).

    Тег шаблона, должен использоваться внутри Цикла WordPress или на странице записи (page.php, single.php), в начале которой вызвана функция the_post().

    Когда функция используется на страницах архивов (не отдельная страница записи) и если в контенте используется тег-разделитель , то эта функция выведет не весь контент, а только текст до тега с последующей ссылкой «читать дальше» (текст ссылки можно изменить через параметр $more_link_text ).

    Смотрите также функцию the_excerpt() — получает отрывок контента поста.

    Хуки из функции

    Возвращает

    null . Выводит на экран отформатированный контент записи.

    Использование

    Под словом «teaser» понимается привлекающий текст до тега . strip_teaser — значит удалить этот текст. Если установить параметр в true, то контент до тега на странице is_single() будет удален.

    Аналогично можно удалить контент до тега more, указав в любом месте кода статьи тег . Обычно его принято указывать сразу после тега .

    По умолчанию: false

    Примеры

    #1 Изменение текста ссылки «читать дальше. «

    Если нужно изменить стандартный текст ссылки, который выводится функций, когда контент обрезается по тегу , то укажите необходимый текст в первом параметре функции:

    #2 Вставка заголовка статьи в текст ссылки «читать дальше. «

    Можно использовать Тег шаблона the_title() , чтобы вставить в текст ссылки «читать дальше. » заголовок записи:

    #3 Изменение поведения функции, относительно обрезки текста по тегу

    Если функция не режет текст по тегу или наоборот, режет, где нам это не нужно, то можно изменить переменную $more, тем самым указав функции резать (0) или не резать (1) текст.

    если нужно оставить контент как есть:

    #4 Игнорируем тег «more» для прилепленных записей (sticky)

    Этот пример будет выводить весь контент для прилепленных записей (даже если в них есть тег «more»), но остальных записей текст будет обрезаться:

    #5 Альтернативное использование

    Если нужно получить контент записи для обработки, а не выводить его на экран, то можно использовать функцию get_the_content() :

    Однако надо иметь ввиду, что полученный контент (который сейчас в переменной $content) не будет отфильтрован. Чтобы его отфильтровать его нужно «прогнать» через фильтр ‘the_content’:

    Источник

    Вывод контента. Как лучше?

    Представим, что мы используем MVC подход и передаем во вьюху некоторый массив данных. Эти данные, на сколько я знаю, можно вывести как минимум двумя путями:

    Так вот, какой из этих способов формирования контента более правильный? На сколько мне известно оператор echo при каждом вызове увеличивает время работы скрипта (по крайней мере в консоли), так будет ли более быстрым вариант использования второго способа, где echo вызывается всего раз. И как вообще принято писать в проектах?

    UPD: Проверил скорость работы двух вариантов вывода. Результаты более чем впечатляющие. Разница в скорости работы примерно в 100 раз. Вот сам скрипт если что.

    2 ответа 2

    Как вариант, делать php-вставки в разметку или использовать (написать свой) шаблонизатор:

    Если, как в первом варианте, использовать echo, то это лишние вызовы функций и работа со стеком параметров. Если, как во втором случае, конкатенировать мелкие значения в одну переменную, то это лишние выделения памяти в общей куче.

    Вариант с вставками кода PHP

    оптимальнее, потому что количество echo меньше, а для накопления результата используется буфер вывода, на который и так уже память выделена.

    В подтверждение моих слов приведу следующий упрощённый код, который применяется в фреймворках, использующий шаблонизаторы класса «pure PHP» :

    Класс View — это компонента View по шаблону проектирования MVC — она передаёт пользовательские параметры $varsв шаблон в виде переменный в локальной области видимости. Файл view.php — это шаблон, то есть файл PHP, в котором непосредственно создаётся фрагмент кода HTML.

    Как видите, в методе render используется буфер.

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

    Источник

    Читайте также:  Как чистить пуховый платок