Wordpress 自定义小部件显示在错误的位置
Wordpress custom widgets shows in wrong position
我想在我的自定义 Wordpress 主题中显示一个联系人小部件,所以我将它放在一个短代码中,以便我可以随时随地调用它。问题是短代码显示在我放置短代码的原始代码之上。小部件、普通文本字段等都会发生这种情况。
首先我添加了这行
add_filter( 'widget_text', 'do_shortcode' );
启用显示简码的字段。
在我的 functions.php 中,我放置了以下代码,我用联系信息调用模板部分。我看到另一个主题,他们通过 return
'ing 一个变量解决了这个问题。
// contact widget
function contact_info_shortcode() {
$contact = get_template_part('includes/sections/contact', 'info');
return $contact;
}
add_shortcode('contact_info', 'contact_info_shortcode');
在该代码中,我调用了以下显示我的联系信息的模板文件
<?php
$contact_title = get_field('contact-titel', 'option');
$phone = get_field('telefoon', 'option');
$email = get_field('e-mail', 'option');
$adress = get_field('adres', 'option');
$place = get_field('plaats', 'option');
;?>
<table class="contact-table">
<!-- telefoon -->
<tr>
<td><i class="fas fa-phone"></i></td>
<td><a class="contact-info-link" href="<?php echo $phone['url'];?>" target="<?php echo $phone['target'];?>"><?php echo $phone['title'];?></a></td>
</tr>
<!-- email -->
<tr>
<td><i class="fas fa-envelope"></i></td>
<td><a class="contact-info-link" href="<?php echo $email['url'];?>" target="<?php echo $email['target'];?>"><?php echo $email['title'];?></a></td>
</tr>
<!-- adres -->
<tr>
<td><i class="fas fa-map-marker-alt"></i></td>
<td>
<p class="contact-info-adress"><?php echo $adress;?></p>
<p class="contact-info-adress"><?php echo $place;?></p>
</td>
</tr>
</table>
希望你们知道我做错了什么
这是因为 get_template_part()
实际上只是一个包含的包装器,它本质上是 echoing
模板部分,因此您不能将其分配给变量。
您需要做的是将模板部分保存在 output buffer
中,然后 return 输出缓冲区。
function contact_info_shortcode() {
// Here we start the output buffer.
ob_start();
// This is now held in the output buffer.
get_template_part('includes/sections/contact', 'info');
// Now we can return the data in the output buffer.
return ob_get_clean();
}
add_shortcode('contact_info', 'contact_info_shortcode');
我想在我的自定义 Wordpress 主题中显示一个联系人小部件,所以我将它放在一个短代码中,以便我可以随时随地调用它。问题是短代码显示在我放置短代码的原始代码之上。小部件、普通文本字段等都会发生这种情况。
首先我添加了这行
add_filter( 'widget_text', 'do_shortcode' );
启用显示简码的字段。
在我的 functions.php 中,我放置了以下代码,我用联系信息调用模板部分。我看到另一个主题,他们通过 return
'ing 一个变量解决了这个问题。
// contact widget
function contact_info_shortcode() {
$contact = get_template_part('includes/sections/contact', 'info');
return $contact;
}
add_shortcode('contact_info', 'contact_info_shortcode');
在该代码中,我调用了以下显示我的联系信息的模板文件
<?php
$contact_title = get_field('contact-titel', 'option');
$phone = get_field('telefoon', 'option');
$email = get_field('e-mail', 'option');
$adress = get_field('adres', 'option');
$place = get_field('plaats', 'option');
;?>
<table class="contact-table">
<!-- telefoon -->
<tr>
<td><i class="fas fa-phone"></i></td>
<td><a class="contact-info-link" href="<?php echo $phone['url'];?>" target="<?php echo $phone['target'];?>"><?php echo $phone['title'];?></a></td>
</tr>
<!-- email -->
<tr>
<td><i class="fas fa-envelope"></i></td>
<td><a class="contact-info-link" href="<?php echo $email['url'];?>" target="<?php echo $email['target'];?>"><?php echo $email['title'];?></a></td>
</tr>
<!-- adres -->
<tr>
<td><i class="fas fa-map-marker-alt"></i></td>
<td>
<p class="contact-info-adress"><?php echo $adress;?></p>
<p class="contact-info-adress"><?php echo $place;?></p>
</td>
</tr>
</table>
希望你们知道我做错了什么
这是因为 get_template_part()
实际上只是一个包含的包装器,它本质上是 echoing
模板部分,因此您不能将其分配给变量。
您需要做的是将模板部分保存在 output buffer
中,然后 return 输出缓冲区。
function contact_info_shortcode() {
// Here we start the output buffer.
ob_start();
// This is now held in the output buffer.
get_template_part('includes/sections/contact', 'info');
// Now we can return the data in the output buffer.
return ob_get_clean();
}
add_shortcode('contact_info', 'contact_info_shortcode');