CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


Posted in HTML / CSS onJune 03, 2013

在平常项目中,偶尔也会涉及一些前端的设计,但毕竟不是专业的,所以一直想要系统的学习一下。最近辞职了,等待入职新公司的期间,有空折腾学习一些CSS3的知识。
今天就从一个简单的圆形菜单的实现,来总结一些最近学习的收获。效果图如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


下面,就来看看这个圆形半透明的菜单如何实现:
1. 我们使用一个 ul 来制作菜单,代码如下:
复制代码
代码如下:

<ul>
<li>
<a href="#">
<span>首页</span>
</a>
</li>
<li>
<a href="#">
<span>用户</span>
</a>
</li>
<li>
<a href="#">
<span>活动</span>
</a>
</li>
</ul>

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


2. 为ul添加样式(ulMenu)以及其下的li,a,span,美化一下菜单:
复制代码
代码如下:

.ulMenu {
list-style: none;
}
.ulMenu li {
float: left;
height: 80px;
width: 80px;
padding: 0;
margin: 0;
text-align: center;
list-style: none;
margin: 10px 10px 0 0;
}
.ulMenu li a {
display: block;
height: 100%;
padding: 0 15px;
font-size: 12px;
font-weight: bold;
color: #ccc;
text-decoration: none;
}
.ulMenu li a span {
display: block;
}

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)

3. 如何让菜单变成圆的,其实只要先将元素设置为长宽相等的正方形,再设置圆角为其长度的一半即可,例如,此例子中,li 的长宽是80px,则我们设置其圆角为40px,我们将 li 的样式改为如下,增加圆角和背景色:
复制代码
代码如下:

.ulMenu li
{
float: left;
height: 80px;
width: 80px;
padding: 0;
margin: 0;
text-align: center;
list-style: none;
background: rgba(0,0,0,0.3);
border-radius: 40px;
-moz-border-radius:40px;
-webkit-border-radius: 40px;
margin:10px 10px 0 0;
}

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


4. 这样离我们要的效果还有些差距,我们要加一些图标上去。CSS3的可以引入font字体可以让我们省去找图标的麻烦,我们可以直接引入font字体文件,这个下一步再详细说,这里,我们先改动一下菜单的 html 代码,用 个容器来显示图标,这里我们用 i 元素,改动后代码如下:
复制代码
代码如下:

<ul class="ulMenu">
<li>
<a href="#">
<i></i>
<span>
首页
</span>
</a>
</li>
<li>
<a href="#">
<i></i>
<span>
用户
</span>
</a>
</li>
<li>
<a href="#">
<i></i>
<span>
活动
</span>
</a>
</li>
<div style="clear:both;">
</div>
</ul>

给 i 添加样式:
复制代码
代码如下:

.ulMenu li a i
{
display: inline-block;
width: 24px;
height: 24px;
margin-top: 17px;
margin-bottom: .25em;
font-size: 28px;
}

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


5. 网上定制的font字体现在附带很多常见图标(可参照 http://astronautweb.co/snippet/font-awesome/ ,字体可到此处下载):

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


下载font字体,在样式文件中引用:
复制代码
代码如下:

@font-face {
font-family: 'FontAwesome';
src: url('font/fontawesome-webfont.eot');
src: url('font/fontawesome-webfont.eot?#iefix') format('embedded-opentype'),
url('font/fontawesome-webfont.woff') format('woff'),
url('font/fontawesome-webfont.ttf') format('truetype'),
url('font/fontawesome-webfont.svgz#FontAwesomeRegular') format('svg'),
url('font/fontawesome-webfont.svg#FontAwesomeRegular') format('svg');
font-weight: normal;
font-style: normal;
}

6. 接着,我们可以用下面形似的样式来制定图标:
复制代码
代码如下:

.css:before {
content: "\f001";
}

但是图标很多,我们可以直接引入下载的font文件下面css文件夹下的 font-awesome.css样式文件,也就是说,上面的一大堆字体文件引用都可以省略为(当然,真实开发中考虑到模块化引入css加载性能略影响,个人觉得应少用,希望有经验的前辈赐教):
复制代码
代码如下:

@import url('font-awesome.css');

为 i 添加对应 css:
复制代码
代码如下:

<ul class="ulMenu">
<li>
<a href="#">
<i class="icon-home">
</i>
<span>
首页
</span>
</a>
</li>
<li>
<a href="#">
<i class="icon-user">
</i>
<span>
用户
</span>
</a>
</li>
<li>
<a href="#">
<i class="icon-th-large">
</i>
<span>
活动
</span>
</a>
</li>
<div style="clear:both;">
</div>
</ul>

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


7. 最后一步,添加鼠标移动上去时改变颜色,添加如下样式:
复制代码
代码如下:

.ulMenu li a:hover {
color: #F90;
}

效果如下:

CSS3+font字体文件实现圆形半透明菜单具体步骤(图解)


猛戳【demo】下载例子。
HTML / CSS 相关文章推荐
一款纯css3实现的圆形旋转分享按钮旋转角度可自己调整
Sep 02 HTML / CSS
使用HTML5 Canvas绘制直线或折线等线条的方法讲解
Mar 14 HTML / CSS
你可能不熟练的十个前端HTML5经典面试题
Jul 03 HTML / CSS
canvas三角函数模拟水波效果的示例代码
Jul 03 HTML / CSS
HTML5实现分享到微信好友朋友圈QQ好友QQ空间微博二维码功能
Jan 03 HTML / CSS
IE10 Error.stack 让脚本调试更加方便快捷
Apr 22 HTML / CSS
HTML5视频支持检测(检查浏览器是否支持视频播放)
Jun 08 HTML / CSS
使用jquery实现HTML5响应式导航菜单教程
Apr 02 HTML / CSS
html5中canvas图表实现柱状图的示例
Nov 13 HTML / CSS
iphoneX 适配客户端H5页面的方法教程
Dec 08 HTML / CSS
HTML5触摸事件实现移动端简易进度条的实现方法
May 04 HTML / CSS
前端水印的简单实现代码示例
Dec 02 HTML / CSS
css3弹性盒模型实例介绍
May 27 #HTML / CSS
深入CSS3 动画效果的总结详解
May 09 #HTML / CSS
基于CSS3特效之动画:animation的应用
May 09 #HTML / CSS
纯CSS3实现手风琴风格菜单具体步骤
May 06 #HTML / CSS
CSS3——齿轮转动关键代码
May 02 #HTML / CSS
如何利用CSS3制作3D效果文字具体实现样式
May 02 #HTML / CSS
使用JS+CSS3技术:让你的名字动起来
Apr 27 #HTML / CSS
You might like
雄兵连三大错觉:凯莎没了,凉冰阵亡了,华烨觉得自己又行了
2020/04/09 国漫
PHP基于IMAP收取邮件的方法示例
2017/08/07 PHP
kindeditor 加入七牛云上传的实例讲解
2017/11/12 PHP
PHP实现的微信公众号扫码模拟登录功能示例
2019/05/30 PHP
laravel框架实现敏感词汇过滤功能示例
2020/02/15 PHP
JQuery浮动DIV提示信息并自动隐藏的代码
2010/08/29 Javascript
AngularJS HTML编译器介绍
2014/12/06 Javascript
Javascript中获取对象的原型对象的方法小结
2015/02/25 Javascript
js上传图片及预览功能实例分析
2015/04/24 Javascript
Javascript中String的常用方法实例分析
2015/06/13 Javascript
在jQuery中使用$而避免跟其它库产生冲突的方法
2015/08/13 Javascript
json+jQuery实现的无限级树形菜单效果代码
2015/08/27 Javascript
关于JavaScript和jQuery的类型判断详解
2016/10/08 Javascript
Node解决简单重复问题系列之Excel内容的获取
2018/01/02 Javascript
解决layer弹出层msg的文字不显示的问题
2019/09/11 Javascript
基于JavaScript伪随机正态分布代码实例
2019/11/07 Javascript
vue子组件改变父组件传递的prop值通过sync实现数据双向绑定(DEMO)
2020/02/01 Javascript
详解Typescript 内置的模块导入兼容方式
2020/05/31 Javascript
[01:52]2020年DOTA2 TI10夏季活动预告片
2020/07/15 DOTA
Python的Twisted框架中使用Deferred对象来管理回调函数
2016/05/25 Python
python安装cx_Oracle模块常见问题与解决方法
2017/02/21 Python
Python实现迭代时使用索引的方法示例
2018/06/05 Python
python 创建一个空dataframe 然后添加行数据的实例
2018/06/07 Python
使用python将图片格式转换为ico格式的示例
2018/10/22 Python
django之对FileField字段的upload_to的设定方法
2019/07/28 Python
python绘制规则网络图形实例
2019/12/09 Python
使用OpenCV circle函数图像上画圆的示例代码
2019/12/27 Python
英国最红的高街时尚品牌:Topshop
2016/08/05 全球购物
澳大利亚优质葡萄酒专家:Vintage Cellars
2019/01/08 全球购物
澳大利亚最好的电动自行车:Leon Cycle
2020/12/19 全球购物
大学旷课检讨书
2014/01/28 职场文书
致百米运动员广播稿
2014/01/29 职场文书
小学生作文评语大全
2014/04/21 职场文书
关于读书的演讲稿800字
2014/08/27 职场文书
工作检讨书范文
2015/01/23 职场文书
python内置进制转换函数的操作
2021/06/02 Python