2011年12月16日星期五

WordPress 3.3 版背景功能失效解决方案

 
 

satan 通过 Google 阅读器发送给您的内容:

 
 

于 11-12-16 通过 知更鸟 作者:知更鸟

随着WordPress 3.3正式版的发布,很多盆友都在第一时间将程序升级到最新版,不过很快发现某些具备"背景"功能的主题(包括 HotNews主题)之前设置的背景失效了。

WordPress早在2.8版就增加了自定义背景body_class()函数,直到3.0版才在默认主题中增加了"背景"功能,具备此功能的主题也不是很多,可能大部分主题设计者会觉得这个功能有些鸡肋,简单通过修改CSS样式就可实现的功能,没有必要增加一次数据库查询,但这句body_class()函数初衷,并不是为了简单更换整个站点所有页面的背景,而是方便设计人员灵活的控制不同页面中各个元素样式,大道理不说了,下面说一下具体的解决方案:

方案一 WordPress 3.3版在程序wp-includes目录theme.php中增加一个custom-background 标签,这是造成"背景"功能失效的问题所在,打开theme.php程序文件,在第1797行找到:

  1. body.custom-background { <?php echo trim( $style ); ?> }  

删除其中的 .custom-background 变为:

  1. body { <?php echo trim( $style ); ?> }  

此方法适合所有之前支持"背景"功能的主题,但需修改程序文件,本人不建议使用。

方案二 这是标准的解决的方案,打开默认主题Twenty Eleven的header.php模版,你会发现有一句:

  1. <body <?php body_class(); ?>>  

代替了正常的<body>标签,这是关键,将上面的代码替换自己所使用主题header.php模板<body>标签即可。

方案三 用

  1. <body class="custom-background">

替换header.php模版<body>标签,不让其增加额外的标签,此方法方便实用,适合所有主题。

下面专门说一下HotNews Pro 2.7Plus主题解决方案

一、HotNews主题,按方案一修改程序文件后,背景功能将恢复正常,其它无需改动。

二、由于HotNews主题功能结构复杂,如果按方案二操作,需修改的模版文件较多,有些麻烦,但通过折腾主题,你可能会学到更多的知识,下面开始操作:

1、HotNews Pro 2.7Plus主题有6个header模版,分别对应不同的页面布局,打开所有以header开头的模版文件,按方案二的方法替换所有<body>标签。

2、之后查找:

  1. <div class="home">  

修改为:

  1. <div id="home">  

之所以要修改此标签,是因为增加:

  1. <body <?php body_class(); ?>>

后,会在首页自动生成".home"标签,与主题样式冲突,造成首页页面偏左。

3、打开HotNewspro主题styles目录的所有样式文件,修改所有以".home"开头的选择器为"#home",有两处。

三、最简单的方法就是采用方案三,只用:

  1. <body class="custom-background">

替换所有以header开头的模版<body>标签,让其不自动生成".home"标签,比较方便。

 


 
 

可从此处完成的操作:

 
 

没有评论:

发表评论