使用css如何制作时间ICON方法实践


Posted in HTML / CSS onNovember 12, 2012

最近我在重新设计自己的博客站点,决定用一个日历样式的icon显示时间。以前的解决方案一般是用背景图片,感谢css3,现在我们用css3就能实现这样的功能。我将会用到一些linear-gradients, border radius 和 box shadow这些属性来代替以前的photoshop设计。

photoshop 概念图
使用css如何制作时间ICON方法实践 
很多设计者采用直接在浏览器上设计的方式,但是我还是更喜欢先做photoshop的概念图的方式。虽然现在很多效果可以直接用css实现,但是用photoshop设计效果的方式比不断尝试修改css来最终达到你想要的效果的方式简单很多。
使用css如何制作时间ICON方法实践 
首先创建一个圆角矩形,设置圆角半径为10px,之后我们会用css的border-radius属性实现。
使用css如何制作时间ICON方法实践 
为矩形添加垂直方向的渐变,渐变颜色是从#dad8d8 到 #fcfcfc。
使用css如何制作时间ICON方法实践 
设置1像素的描边,颜色是#e3e3e3
使用css如何制作时间ICON方法实践 
最后添加向下的阴影效果,透明度为20%,0像素的距离和15像素的大小。这些效果在css中将会用box-shadow属性实现。
使用css如何制作时间ICON方法实践 
复制刚才的矩形,移除上边的部分。修改渐变,颜色从#790909 到 #d40000,填充新创建的矩形,这部分将要放置月份信息。
使用css如何制作时间ICON方法实践 
设置一个内阴影来表示上边框,颜色为#a13838,100%透明度,3px的距离和0px的大小。
使用css如何制作时间ICON方法实践 
用photoshop的字体工具设置日历icon上半部分时间内容的字体效果,字体为Helvetica,颜色为#9e9e9e。
使用css如何制作时间ICON方法实践 
在下面红色部分输入月份信息,字体设置为宽,颜色为白色。
使用css如何制作时间ICON方法实践
photoshop的模型就完成了。以前的话,我们会把图片抽出来作为背景,再在上面写上html的数字,但是现在所有这些都可以用css实现。
HTML结构
<div class="date">
<p>25 <span>May</span></p>
</div>
这次时间ICON demo的html非常简单。我们会用带有class为‘date’的div作为容器,然后用一个p标签来表示日期数字。天和月份在我们的设计里用不同大小的字符表示,所以我们会<span>标签来区别对待不同元素。
css样式

复制代码
代码如下:

.date {
width: 130px; height: 160px;
background: #fcfcfc;
background: linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
background: -moz-linear-gradient(top, #fcfcfc 0%, #dad8d8 100%);
background: -webkit-linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
}

使用css如何制作时间ICON方法实践 
css样式首先设置了整个容器的高和宽,通过css的gradient又可以很容易的实现渐变的效果。
复制代码
代码如下:

.date {
width: 130px; height: 160px;
background: #fcfcfc;
background: linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
background: -moz-linear-gradient(top, #fcfcfc 0%, #dad8d8 100%);
background: -webkit-linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
border: 1px solid #d2d2d2;
border-radius: 10px;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
}

使用css如何制作时间ICON方法实践 
用border属性可以实现photoshop中1px边框效果,然后用border-radius实现了圆角的效果。不要忘记加上-moz-和-webkit-前缀,以实现对老版本浏览器的兼容。
复制代码
代码如下:

.date {
width: 130px; height: 160px;
background: #fcfcfc;
background: linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
background: -moz-linear-gradient(top, #fcfcfc 0%, #dad8d8 100%);
background: -webkit-linear-gradient(top, #fcfcfc 0%,#dad8d8 100%);
border: 1px solid #d2d2d2;
border-radius: 10px;
-moz-border-radius: 10px;
-webkit-border-radius: 10px;
box-shadow: 0px 0px 15px rgba(0,0,0,0.1);
-moz-box-shadow: 0px 0px 15px rgba(0,0,0,0.1);
-webkit-box-shadow: 0px 0px 15px rgba(0,0,0,0.1);
}

使用css如何制作时间ICON方法实践 
最后一部分代码,通过box-shadow实现在photoshop设计中的下阴影效果。添加0px的水平和垂直的偏移量,增加15px的模糊度。用rgba实现对透明度的控制,在photoshop设计中的105,在这里换成了0.1。
复制代码
代码如下:

.date p {
font-family: Helvetica, sans-serif;
font-size: 100px; text-align: center; color: #9e9e9e;
}

使用css如何制作时间ICON方法实践
我们用给p标签定义样式,实现了为日期定义文字样式。字体,文字大小,文字颜色都是从photoshop中拷贝得到的,text-align设置为居中。但是样式也同样影响了月份文字,接下来我们会单独为它定义span标签样式。
复制代码
代码如下:

.date p span {
background: #d10000;
background: linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -moz-linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -webkit-linear-gradient(top, #d10000 0%, #7a0909 100%);
}

使用css如何制作时间ICON方法实践
红色部分的实现是通过为span的背景设置linear-gradient属性实现的,红色的数值也是来自于photoshop。
复制代码
代码如下:

.date p span {
background: #d10000;
background: linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -moz-linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -webkit-linear-gradient(top, #d10000 0%, #7a0909 100%);
font-size: 45px; font-weight: bold; color: #fff; text-transform: uppercase;
display: block;
}

使用css如何制作时间ICON方法实践 
修改文字样式,使它和设计匹配,大小设置为45px,设置为粗体字,颜色设置为白色,使用text-transform实现大写转换。将span标签设置为块元素,这样他就会匹配容器的大小了,设置红色背景。
复制代码
代码如下:

.date p span {
background: #d10000;
background: linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -moz-linear-gradient(top, #d10000 0%, #7a0909 100%);
background: -webkit-linear-gradient(top, #d10000 0%, #7a0909 100%);
font-size: 45px; font-weight: bold; color: #fff; text-transform: uppercase;
display: block;
border-top: 3px solid #a13838;
border-radius: 0 0 10px 10px;
-moz-border-radius: 0 0 10px 10px;
-webkit-border-radius: 0 0 10px 10px;
padding: 6px 0 6px 0;
}

使用css如何制作时间ICON方法实践 
剩下的就是添加头部边框,用border-top样式实现,还有就是用border-radius属性实现下部两个圆角。一点点的padding属性可以让月份文字上下和其他元素有些间隔。
浏览器兼容性
使用css如何制作时间ICON方法实践 
尽管css改进的属性可以帮助我们实现photoshop中渐变和阴影的效果,但是我们仍然要面对以前web设计师要面对的问题,浏览器兼容性。
HTML / CSS 相关文章推荐
HTML5如何适配 iPhone IOS 底部黑条
Mar 09 HTML / CSS
使用css3实现的tab选项卡代码分享
Dec 09 HTML / CSS
HTML5是什么 HTML5是什么意思 HTML5简介
Oct 26 HTML / CSS
HTML5之SVG 2D入门10—滤镜的定义及使用
Jan 30 HTML / CSS
html5 的a标签 Href 拨电话的写法
Nov 04 HTML / CSS
HTML5 audio标签使用js进行播放控制实例
Apr 24 HTML / CSS
基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作
Jan 11 HTML / CSS
HTML5 canvas实现移动端上传头像拖拽裁剪效果
Mar 14 HTML / CSS
HTML5 Canvas绘制五星红旗
May 04 HTML / CSS
canvas里面如何基于随机点绘制一个多边形的方法
Jun 13 HTML / CSS
HTML5 manifest离线缓存的示例代码
Aug 08 HTML / CSS
HTML5输入框下拉菜单功能的示例代码
Sep 08 HTML / CSS
浅谈three.js中的needsUpdate的应用
Nov 12 #HTML / CSS
HTML5教程之html 5 本地数据库(Web Sql Database)
Apr 03 #HTML / CSS
用HTML5实现手机摇一摇的功能的教程
Oct 30 #HTML / CSS
HTML5是什么 HTML5是什么意思 HTML5简介
Oct 26 #HTML / CSS
HTML 5 标签、属性、事件及浏览器兼容性速查表 附打包下载
Oct 20 #HTML / CSS
HTML5上传文件显示进度的实现代码
Aug 30 #HTML / CSS
input元素的url类型和email类型简介
Jul 11 #HTML / CSS
You might like
使用XDebug调试及单元测试覆盖率分析
2011/01/27 PHP
thinkphp5.1框架实现格式化mysql时间戳为日期的方式小结
2019/10/10 PHP
baidu博客的编辑友情链接的新的层窗口!经典~支持【FF】
2007/02/09 Javascript
更换select下拉菜单背景样式的实现代码
2011/12/20 Javascript
在JavaScript中typeof的用途介绍
2013/04/11 Javascript
jQuery判断复选框是否勾选的原理及示例
2014/05/21 Javascript
给js文件传参数(详解)
2014/07/13 Javascript
jQuery实现dialog设置focus焦点的方法
2015/06/10 Javascript
Jquery常用的方法汇总
2015/09/01 Javascript
jQuery中Nicescroll滚动条插件的用法
2016/11/10 Javascript
巧用数组制作图片切换js代码
2016/11/29 Javascript
jQuery插件HighCharts实现的2D对数饼图效果示例【附demo源码下载】
2017/03/09 Javascript
基于layer.js实现收货地址弹框选择然后返回相应的地址信息
2017/05/26 Javascript
npm国内镜像 安装失败的几种解决方案
2017/06/04 Javascript
vue bootstrap小例子一枚
2017/06/09 Javascript
vue中实现methods一个方法调用另外一个方法
2018/02/08 Javascript
bootstrap table实现合并单元格效果
2018/12/24 Javascript
微信小程序实现日期格式化和倒计时
2020/11/01 Javascript
[53:49]LGD vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
[01:18]PWL开团时刻DAY4——圣剑与抢盾
2020/11/03 DOTA
[01:04:20]完美世界DOTA2联赛PWL S2 LBZS vs Forest 第一场 11.29
2020/12/02 DOTA
Python函数可变参数定义及其参数传递方式实例详解
2015/05/25 Python
Python正则表达式教程之二:捕获篇
2017/03/02 Python
python中如何使用正则表达式的集合字符示例
2017/10/09 Python
python做量化投资系列之比特币初始配置
2018/01/23 Python
详谈python3中用for循环删除列表中元素的坑
2018/04/19 Python
pyqt5实现俄罗斯方块游戏
2019/01/11 Python
python并发编程 Process对象的其他属性方法join方法详解
2019/08/20 Python
python如何输出反斜杠
2020/06/18 Python
美国开幕式潮店:Opening Ceremony
2018/02/10 全球购物
美国购买新书和二手书网站:Better World Books
2018/10/31 全球购物
美国体育用品商店:Academy Sports + Outdoors
2020/01/04 全球购物
心理健康教育制度
2014/01/27 职场文书
生物技术专业求职信
2014/06/10 职场文书
工伤调解协议书
2016/03/21 职场文书
JS实现简单九宫格抽奖
2022/06/28 Javascript