无插件实现 wordpress 彩色标签云效果

一、随机颜色

将以下代码放入主题包 functions.php 文件内:

function colorCloud($text) { 
$text = preg_replace_callback('|<a (.+?)>|i', 'colorCloudCallback', $text);
return $text;
} 
function colorCloudCallback($matches) { 
$text = $matches[1];
$color = dechex(rand(0,16777215));
$pattern = '/style=(\'|\")(.*)(\'|\")/i';
$text = preg_replace($pattern, "style=\"color:#{$color};$2;\"", $text);
return "<a $text>";
} 
add_filter('wp_tag_cloud', 'colorCloud', 1);

第8行代码”$color=dechex(rand(0,16777215));”:作用是定义标签随机颜色的十进制数值范围,0 等于 #000000,16777215 等于 #ffffff。你可以使用进制换算工具换算后修改这行代码,改变颜色范围。

在主题需要的地方加入以下代码:

wp_tag_cloud('smallest=8&largest=24&number=50'); 

代码说明:

  • “smallest”:最小的字体尺寸(使用频率最少的标签)
  • “largest”:最大的字体尺寸(频率最多的)
  • “number”:则表示标签显示数量。

KO!

from:http://hezi.info/share/wordpress/wordpress-colore-tag.html

二、自定义颜色

function colorCloudCallback($matches) {
$tag_link=$matches[1];
/*颜色集合*/
$colorFull = array(‘#999′,’#D8D9A4′,’#9BB’,'#EB9′,’#a3c159′,’#FEC42D’,'#6C8C37′,
‘#c2dc15′,’#3371A3′,’#888′,’#00ccff’,'#FF8080′);
$color=$colorFull[ mt_rand(0, count($colorFull) - 1)];
$pattern = ‘/style=(\’|\”)(.*)(\’|\”)/i’;
$tag_link= preg_replace($pattern, “style=\”color:{$color};$2;\”", $tag_link);
return “<a $tag_link>”;
}
add_filter(‘wp_tag_cloud’, ‘colorCloud’, 1);

from:http://mcooo.com/

作者: LMS

天行贱,君子自强自息。

标签

《无插件实现 wordpress 彩色标签云效果》有27个想法

  1. function colorCloudCallback($matches) {
    $tag_link=$matches[1];
    /*颜色集合*/
    $colorFull = array(‘#999′,’#D8D9A4′,’#9BB’,’#EB9′,’#a3c159′,’#FEC42D’,’#6C8C37′,
    ‘#c2dc15′,’#3371A3′,’#888′,’#00ccff’,’#FF8080′);
    $color=$colorFull[ mt_rand(0, count($colorFull) – 1)];
    $pattern = ‘/style=(‘|”)(.*)(‘|”)/i’;
    $tag_link= preg_replace($pattern, “style=”color:{$color};$2;””, $tag_link);
    return “<a $tag_link >”;
    }

    add_filter(‘wp_tag_cloud’, ‘colorCloud’, 1);

    有可以自己选的啊,这是我用的。。。 💡

  2. 好方法,不过我用了之后,边栏上的3dflash的标签云就出问题了,字体很大的,请高手帮帮忙 😥

发表评论

电子邮件地址不会被公开。 必填项已用*标注