PHP实现的多彩标签效果代码分享


Posted in PHP onAugust 21, 2014

目前,大家的博客左侧通常加上一个漂亮的多彩标记,也想给自己的小站加一下这个小功能。

可惜已经再不再是使用WordPress的时候那么方便了,使用WordPress的朋友们直接使用现成的插件,鼠标点点就可以加上这个炫彩的功能。小站程序是自个写的,要加这么一个功能还是得自己动手,就当学习吧!

首先,我分析了一下目前多彩标签的主要表现形式,主要有两点:颜色多样,大小不一。这个是多彩标签的特性,于是想到了PHP中的随机函数rand。直接给大小,颜色用rand随机取值就可以。

大小的随机值容易搞定,直接生成后连接单位即可

<?php

// 随机大小实例

$m = rand(20,30);

echo '<span style="font-size:'.$m.'px">随机大小</span>';

?>

生成颜色值稍微麻烦一些,因为颜色值是十六进制字符表现形式,而随机函数rand不能直接生成 0 到 F 这么用,最后直接用数组保存十六进制字符,然后随机生成鼠标下标这样也可以实现随机颜色
<?php

// 随机颜色函数

// 直接返回随机生成的色值

function getColor(){

        // 先用数组把十六进制字符保存在一个数组中

    $arr = array('0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F');

 

        // 因为颜色色值长度是6位,所以循环6次

    for($i=0;$i<6;$i++){

                // 随机生成0到15数字,然后当作数组下标取值即可

        $color .= $arr[rand(0,15)]; 

    }

 

        // 返回的时候,把#号加上

    return ‘#'.$color;

}

?>

随机大小,随机颜色搞定后剩下的都不是问题的问题了。直接取出所有标签然后去重,然后遍历数组生成HTML文本即可。

最后提点建议,毕竟PHP是服务器端,每次都rand会让服务器鸭梨不小(那些特牛的机器可以忽略不计,毕竟目前用VPS的还是众多)。我们可以在博客的标签在发生变动的时候再生成即可,比如删除,修改,增加文章产生新的标签时候我们再去生成多彩标签的HTML文本。最后这些生成的多彩签HTML没必要存进数据库,直接保存在在一个文件里,然后include即可。

目前,我的小站就是这么实现的。有空,我再介绍JavaScript实现多彩标签,原理也差不多一样,只不过是JavaScript是客户端行为,不用担心服务器端的鸭梨,而且JavaScript交互性比较好,可以制作出具有动画效果的云标签。

PHP 相关文章推荐
木翼下载系统中说明的PHP安全配置方法
Jun 16 PHP
PHP 加密解密内部算法
Apr 22 PHP
用sql命令修改数据表中的一个字段为非空(not null)的语句
Jun 04 PHP
php skymvc 一款轻量、简单的php
Jun 28 PHP
PHP mb_convert_encoding文字编码的转换函数介绍
Nov 10 PHP
PHP图片裁剪函数(保持图像不变形)
May 04 PHP
php获取指定日期之间的各个周和月的起止时间
Nov 24 PHP
php将字符串全部转换成大写或者小写的方法
Mar 17 PHP
PHP读取配置文件类实例(可读取ini,yaml,xml等)
Jul 28 PHP
PHP中使用jQuery+Ajax实现分页查询多功能操作(示例讲解)
Sep 17 PHP
Yii框架页面渲染操作实例详解
Jul 19 PHP
php-fpm超时时间设置request_terminate_timeout资源问题分析
Sep 27 PHP
又一个PHP实现的冒泡排序算法分享
Aug 21 #PHP
PHP中几个可以提高运行效率的代码写法、技巧分享
Aug 21 #PHP
个人写的PHP验证码生成类分享
Aug 21 #PHP
PHP中使用sleep造成mysql读取失败的案例和解决方法
Aug 21 #PHP
从零开始学YII2框架(六)高级应用程序模板
Aug 20 #PHP
ThinkPHP登录功能的实现方法
Aug 20 #PHP
从零开始学YII2框架(五)快速生成代码工具 Gii 的使用
Aug 20 #PHP
You might like
php tp验证表单与自动填充函数代码
2012/02/22 PHP
PHP实现伪静态方法汇总
2016/01/13 PHP
php中namespace及use用法分析
2016/12/06 PHP
php+redis实现商城秒杀功能
2020/11/19 PHP
thinkphp5实现无限级分类
2019/02/18 PHP
详解PHP PDO简单教程
2019/05/28 PHP
判断页面是关闭还是刷新的js代码
2007/01/28 Javascript
理解JSON:3分钟课程
2011/10/28 Javascript
jquery validate添加自定义验证规则(验证邮箱 邮政编码)
2013/12/04 Javascript
Jquery ajaxStart()与ajaxStop()方法(实例讲解)
2013/12/18 Javascript
利用javascript数组长度循环数组内所有元素
2013/12/27 Javascript
JavaScript中string对象
2015/06/12 Javascript
跟我学习javascript的垃圾回收机制与内存管理
2015/11/23 Javascript
js实现的页面矩阵图形变换特效
2016/01/26 Javascript
JS控制div跳转到指定的位置的几种解决方案总结
2016/11/05 Javascript
js原生实现FastClick事件的实例
2016/11/20 Javascript
EasyUi 打开对话框后控件赋值及赋值后不显示的问题解决办法
2017/01/19 Javascript
NodeJS实现图片上传代码(Express)
2017/06/30 NodeJs
vue 项目接口管理的实现
2019/01/17 Javascript
JavaScript继承与聚合实例详解
2019/01/22 Javascript
TypeScript中的方法重载详解
2019/04/12 Javascript
Python正则表达式分组概念与用法详解
2017/06/24 Python
Python Json序列化与反序列化的示例
2018/01/31 Python
详解Python中的四种队列
2018/05/21 Python
Pandas之MultiIndex对象的示例详解
2019/06/25 Python
使用python代码进行身份证号校验的实现示例
2019/11/21 Python
3种适用于Python的疯狂秘密武器及原因解析
2020/04/29 Python
奥地利网上书店:Weltbild
2017/07/14 全球购物
ECOSUSI官网:女式皮革背包
2019/09/27 全球购物
一份创业计划书范文
2014/02/08 职场文书
人事专员岗位职责说明书
2014/07/30 职场文书
2014年医德医风工作总结
2014/11/13 职场文书
再读《皇帝的新衣》的读后感悟!
2019/08/07 职场文书
golang 实现对Map进行键值自定义排序
2021/04/28 Golang
MySQL高级进阶sql语句总结大全
2022/03/16 MySQL
openstack云计算keystone组件工作介绍
2022/04/20 Servers