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

LMS
2.3K+ 27

一、随机颜色

将以下代码放入主题包 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/

THE END

评论 27

  1. 用了 这个方法,页面先死505 报错。。。
    知道怎么处理嘛? 多谢了。

    1. 代码里面的符号都是全角的,你用的时候要换成半角英文符号。

      1. 不管我的事哟!

        都是 知更鸟 惹的“祸”!

            1. 还好,可以接受,就是进去后不知道点哪里。 :mrgreen:

  2. 过来看看,这个方法不太行,可能是我的主题的问题……

    1. 你是出什么问题呢,这个方法我用过,也给别人用过,没发现什么问题啊

      1. 我主题的问题,我看了看,他可能将函数的功能改了……主题制作的稍微有些差!不过外观不错!哈哈!

  3. heson
    🏅

    :twisted: 原来用过 搞忘记方法了 过来再看看``````

  4. 双陈记
    🏅

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

  5. 方圆剑
    🏅

    为了表示感谢 点击了你两个广告

  6. mcooo
    🏅🏅

    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);

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

  7. mcooo
    🏅🏅

    这个选不了自己的颜色!

  8. 万戈
    🏆🏅

    好方法,可惜不适合我的黑白主题

登录 后参与评论,还没有账号的话,快来 注册 一个吧