不用插件实现 WordPress 彩色标签云

solar @ 2009年05月26日 - 唉,你来晚一步,前 12 排已经被占啦 » - 1,341 Views

标签云用到的函数是

  1. <?php wp_tag_cloud(); ?>

有以下几个主要参数:

smallest:最小字体,默认为8
largest:最大字体,默认为22
unit:字符大小的单位(例如pt,px,em),默认为pt
number:显示标签个数(为0时显示所有标签),默认为45
format:显示方式,flat(默认,以空格分隔)
更详细的说明请看 WordPress官方网站
以上各参数以"&"符号连接.不必都填,不填的参数以默认值为准.
根据上面的参数,调用标签云可以像这样:

  1. <?php wp_tag_cloud('number=50&largest=24&smallest=12&unit=px'); ?>

实现彩色标签云的函数

  1. //彩色标签云函数开始
  2. function colorCloud($text) { 
  3. $text = preg_replace_callback('|<a (.+?)>|i', 'colorCloudCallback', $text);
  4. return $text;
  5. } 
  6. function colorCloudCallback($matches) { 
  7. $text = $matches[1];
  8. $color = dechex(rand(0,16777215));
  9. $pattern = '/style=(\'|\")(.*)(\'|\")/i';
  10. $text = preg_replace($pattern, "style=\"color:#{$color};$2;\"", $text);
  11. return "<a $text>";
  12. } 
  13. add_filter('wp_tag_cloud', 'colorCloud', 1);

把上面的代码加入到模板文件的 functions.php 里即可。

效果参见本站的侧边栏和 这里

来源:wanwp.com 作者:冰古

12条 评论 在 “不用插件实现 WordPress 彩色标签云” 之后

  1. 不错的一个方法,谢谢了。

    回复这条留言 - 引用

  2. 很好,用上了 呵呵 谢谢!

    回复这条留言 - 引用

  3. @siory: 我只是转别人的代码,具体你是怎么操作的我不得而知,这个需要基本的php知识,其实也没那么复杂,再试试吧。我也爱莫能助,囧。

    回复这条留言 - 引用

  4. 我加了“确实没有效果,怎么办。

    回复这条留言 - 引用

  5. @Eden: 给你的标签加 line-height 属性,以标签的最大字号为准。比如:你标签的最大字号为30px,那么就给包裹你标签的容器加个 line-height:30px 即可。

    回复这条留言 - 引用

  6. 为啥我的标签效果不好看,反而像是记作一团呢?

    回复这条留言 - 引用

  7. @Louis: 呵呵,这个东西的确意义不大,好玩儿而已吧~~~ :em06:

    回复这条留言 - 引用

  8. 跑到binggu那里看了看留言,又不想加了

    回复这条留言 - 引用

  9. @solar: 呵呵,加上就好了。 :em10:

    回复这条留言 - 引用

  10. @bingu: 抱歉,在我搜索这个功能的时候,第一个看到是“有道快贴”里的文章,而这里没有给出任何作者的信息,因此我无从确认原始的作者及出处,你可以看一下我的其他文章只要是非原创的只要有确切的出处及作者信息我都会标明的。谢谢你的提醒我已经署名了。 :em21:

    回复这条留言 - 引用

  11. 这个代码是我写的吧,根据CC也应该要留个链接吧。

    回复这条留言 - 引用

注意:欢迎任何评论,但管理员保留编辑、修改与删除的权利。

在IE里可能无法发表评论(原因不明,囧~~~),请使用 Opera 或 Firefox ,或者其他任何非IE浏览器!


  • :em02:
  • :em11:
  • :em15:
  • :em14:
  • :em08:
  • :em21:
  • :em20:
  • :em04:
  • :em16:
  • :em13:
  • :em09:
  • :em18:
  • :em10:
  • :em19:
  • :em06:
  • :em01:
  • :em05:
  • :em03:
  • :em22:
  • :em07:
  • :em12:
  • :em17:


(Ctrl + Enter 快速提交)