为WordPress每篇日志定义不同背景

你是否想像Nometet.com 这个网站一样让每篇博客文章的背景看起来都不一样呢?这个网站的设计确实是非常酷的,因为它允许作者通过上传图片来自定义文章背景,而且甚至图片的尺寸也 没有特别的规定。上传并不困难,只要在meta盒里执行一个上传软件就可以了,主要还是在选择图片上,让我们来看看究竟如何实现的呢?

考虑到后面需要用上传软件将图片的URL地址保存到一个自定义字段里,所以我们先将自定义字段建好,这样一来你只需要将URL收到自定义字段里并将 其显示为背景即可,代码非常简单:

  1. <?php
  2. = get_post_custom_values();
  3. ( () ) { ?>
  4. <style type= media=>
  5. body{ background: url(<?php ?>) fixed no-repeat; }
  6. </style>
  7. <?php } ?>

不过你还得修改图片尺寸并将URL拷贝到自定义字段里。

自定义 meta上传软件

我们需要一个上传软件,究竟该如何实现呢?通过对WooThemes的研究,我发现他们的主题里有一个admin-custom.php文件(在 /functions目录下),这是他们用来加上传软件以及其他自定义meta盒的地方。

你可以从这 里下载此文件。

下载完之后,复制所有代码并将其粘贴到你的functions.php文件里(注意要粘贴在结束的?>标签之后)。

接着,需要启动meta盒,可以用下面的代码来实现:

  1. = (
  2. => (
  3. => ,
  4. => ,
  5. => ,
  6. =>
  7. ),
  8. );
  9. update_option(\’woo_custom_template\’,);

这段代码必需添 加在其他代码之后结束的?>标签之前。保存并上传文件,这样就你就有了上传软件,它会将图片保存到自定义字段 ‘bg’里。

调整图像大小

最后需要使用timthumb来调整图像的宽度为1920像素,首先下载timthumb, 并将它上传到你的主题文件里,头部的代码要遵守timbthumb的句法:

  1. body{
  2. background: url(<?php bloginfo(\’template_url\’); ?>/tools/timthumb.php?w=1920&zc=1&src=<?php ; ?>) fixed no-repeat;
  3. }

你会发现使用上面的代码是行不通的,因为timthumb不喜欢自定义字段里的图片URL地址http://… 。

最后别人告诉我需要将URL地址编译才行,于是把上面的代码替换成:

  1. body{
  2. background: url(<?php bloginfo(\’template_url\’); ?>/tools/timthumb.php?w=1920&zc=1&src=<?php urlencode(); ?>) fixed no-repeat;
  3. }

完成!

原文:http://wpshout.com/

    © 版权声明
    THE END
    喜欢就支持一下吧
    点赞0 分享
    评论 抢沙发

    请登录后发表评论

      暂无评论内容