Я использую WordPress уокер класс добавить часть шаблона после меню li
, однако он вставляет части шаблона над всей структурой меню. Вот что у меня есть
class bt_menu_walker extends Walker_Nav_Menu
{
public function end_el(&$output, $item, $depth = 0, $args = array()) {
$dir = get_template_directory() . '/partials';
// Get file names from 'partials' directory
$scan = scandir($dir);
// Get css class names from menu elements
$classes = empty( $item->classes ) ? array() : (array) $item->classes;
foreach($scan as $file) {
// Only grab files
if (!is_dir("$file")) {
// Just raw filenames
$strip_extension = pathinfo($file, PATHINFO_FILENAME);
// Match css class with filenames
if ($classes[0] == $strip_extension) {
// Append template part after closing </li>
$output .= "</li>" . get_template_part( 'partials/' . $strip_extension );
}
}
}
}
}
Как я уже проверял, когда я добавляю другой HTML в $output
отображается сразу после закрытия </li>
элемент, как и ожидалось. Почему get_template_part
сделать выше структуры меню?
Потому что части шаблона выводят эхо прямо в браузер, а меню находится в $ output и будет позже выведено. (это, наверное, очень плохой английский)
Включите буферизацию вывода, чтобы получить вывод части шаблона:
if ($classes[0] == $strip_extension) {
// Append template part after closing </li>
$output .= "</li>";
ob_start();
get_template_part( 'partials/' . $strip_extension );
$output .= ob_get_clean();
}
Увидеть ob_start () а также ob_get_clean () для объяснения.
Кстати. <ul>
элемент должен содержать только <li>
элементы. Может быть, это не лучшее место для вашего дополнительного выхода.
Других решений пока нет …