【发布时间】:2012-05-29 17:44:28
【问题描述】:
这里是在我当前使用的 wordpress 主题上显示标题部分的代码。
<div id="site-branding" class="clearfix">
<?php
$logo = isset($options['logo'])? $options['logo']: '';
if ($logo == ""){
$hidetitle = $options['hide_title'];
if ($hidetitle == "No") {
if(!is_home() || !is_front_page()) { ?>
<div class="site-title"><a href="<?php echo esc_url( home_url( '/' ) ); ?>" title="<?php echo esc_attr( get_bloginfo( 'name', 'display' ) ); ?>"><?php bloginfo('name'); ?></a></div>
<div class="site-description"><?php bloginfo('description'); ?></div>
<?php } else { ?>
<h1 class="site-title"><a href="<?php echo esc_url( home_url( '/' ) ); ?>" title="<?php echo esc_attr( get_bloginfo( 'name', 'display' ) ); ?>"><?php bloginfo('name'); ?></a></h1>
<div class="site-description"><?php bloginfo('description'); ?></div>
<?php } }
} else {
echo '<div class="site-logo"><a href="'. esc_url( home_url( '/' ) ) .'">';
echo '<img title="'. get_bloginfo('name') .'" src="' . $logo .'" />';
echo '</a></div>';
} ?>
</div><!-- end #site-branding -->
此代码的第一部分检查徽标的存在。如果徽标不存在,它将仅显示主题的名称和描述,前提是未在主题选项中选中隐藏。它会使主页/首页上的名称和描述的样式略有不同,而在其他页面上的样式则不同。但是,如果存在徽标,它将在所有页面上显示该徽标。
现在我想要实现的是(使用 CSS)在 Front/Home 页面上以不同的方式设置 LOGO 样式,而在其他页面上我想为 logo 添加一些额外的 css 类。
我尝试在上面代码的第二部分使用 elseif 语句,但无法得到想要的结果。
请建议我如何正确地做到这一点。
更新: 因为我不能发布我自己问题的答案,所以我在这里发布。 好吧,我在删除了一些 PHP 关闭元素后使用了这段代码,它就像魅力一样。我在这里再次发布它只是为了确保没有错误。
if(is_home() || is_front_page()) {
echo '<h1 class="site-logo"><a href="'. esc_url( home_url( '/' ) ) .'">';
echo '<img calss="mylogo1" title="'. get_bloginfo('name') .'" src="' . $logo .'" />';
echo '</a></h1>';
} else {
echo '<div class="site-logo"><a href="'. esc_url( home_url( '/' ) ) .'">';
echo '<img calss="mylogo2" title="'. get_bloginfo('name') .'" src="' . $logo .'" />';
echo '</a></div>';
} ?>
【问题讨论】:
标签: php css wordpress themes wordpress-theming