我使用wordpress walker class在菜单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
呈现在菜单结构上方?
答案 0 :(得分:0)
因为模板部件直接将echo输出到浏览器,而菜单是$ 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>
个元素。也许这不是你额外输出的最佳位置。