许多应用软件的主菜单都具有这样的效果,通常是暗色的,一旦鼠标移到菜单上,立即变明亮;鼠标不在菜单上时是平面的,一旦鼠标移到菜单上,菜单条立即变为立体,从而增强了菜单的效果。你是否也想使网页中的导航菜单产生这种迷人的效果?那么请看下面这个菜单效果。
鼠标不在菜单上
    
   鼠标在菜单上
    
     上面这种菜单效果的制作思路是这样的:利用CSS属性可以动态改变的特点,我们先定义两组CSS,一组是鼠标不在菜单上的CSS,另一组是鼠标在菜单上用 的CSS。再在onmouseover和onmouseout事件中分别调用不同的CSS就能实现本例的效果了。下面讲具体的制作方法:
1、先作一个1*4的表格,在表格中填入菜单名称并设置好链接;
2、为了使菜单产生立体效果,实际上只要把菜单的上边框线和左边框设置为白色,右边框线和下边框线设置为黑色,就能产生立体效果了。在 Dreamweaver3中按F7(或点击快速启动栏里那个象“八卦图”似的图标),调出CSS面板,选择“none”,再点击面板下部的编辑图标,在弹 出的“Edit Style Sheet”对话框上按“New”按钮,在弹出的“New Style”对话框中选择“Make Custom Style (class)”后,在下面的“Name”输入框中输入“.menustyle1”(也就是给要定义的class取个名字,注意前面那个小点不要漏了), 按OK,立即弹出“Style Definition for menustyle1”对话框,这时就开始定义CSS的“style1”了。在左边的选择窗口中选择“Border”,在右边的面板上定义(也是选择), 在“style”属性中选择“solid(实线)”;在“Top”中输入“1”;然后把“Top”“left”的颜色定义为“#FFFFFF”(白色), “bottom”“right”的颜色定义为“#000000”(黑色)。到此,“menustyle1”已全部定义好,按OK返回,在“Edit Style Sheet”对话框上按“Done”按钮结束。我们再用同样的方法定义一个“menustyle2”的CSS,在鼠标移开时用,定义的方法相同,只是在定 义边框线颜色时,把四条边框线的颜色取与菜单背景相同的颜色。在这里顺便讲一下,直接把边框线的宽度设置为“0”,也能达到类似的效果,但整个页面要抖动 一下,效果不好。
3、为了达到整个菜单条在通常是暗色,鼠标在上面时是明亮色的效果,要设置两个CSS的alpha滤镜,menustyle3和menustyle4,在 Dreamweaver中设置CSS滤镜在方法上与一般的CSS设置相同(具体可参看“CSS滤镜应用技巧”专题),只是“alpha”滤镜的参数较多, 其实在这里只要其中的一个参数就行了,我在这里给出CSS代码,直接加在〈head〉和〈/head〉之间也行。CSS全部设置好后,在〈head〉和 〈/head〉之间可见到这样的代码:
〈style type="text/css"〉
〈!--
.menustyle1 { border: solid; border-width: 1px 1px 1px 1px; border-color: #FFFFFF #000000 #000000 #FFFFFF}
.menustyle2 {border:solid;border-width:1px;border-color:#ccccff;}
.menustyle3 {filter:alpha(opacity=60)}
.menustyle4 {filter:alpha(opacity=100)}
.
--〉
〈/style〉
4、CSS都做好了,下面开始加载到相应的地方去。我们在源代码中找到第一个菜单项所在的“〈td〉”,在其中加上这样一行代码:onmouseover ="this.className='menustyle1'" οnmοuseοut="this.className= 'menustyle2'" class="menustyle2",这行代码的作用是当鼠标在这个菜单上时,使用menustyle1定义的格式,当鼠标移开时使用 menustyle2定义的格式,后面那个class="menustyle2"的作用是当前面两个事件都没有发生时,仍使用menustyle2格式, 从而保证了菜单的一致性。对其它菜单项同样也加上这行代码。这样菜单项就能随着鼠标的移动而从立体、平面之间相互转换了。 5、在表格的〈table〉 标记中加上这样一行代码:οnmοuseοver="this.className='menustyle4'" οnmοuseοut="this.className='menustyle3'" class="menustyle3",这行代码的作用与上面类似,只是这里改变的是透明度,从视觉上产生一种明暗程度相互转换的效果。

到此,制作全部结束,按F12看看效果吧!用 Dreamweaver3自动生成的CSS代码稍多一点,若对CSS熟悉的话,可直接编写,不是用Dreamweaver的网友,也可以把代码直接加在相 应的位置即可。本例旨在抛砖引玉,提出一种方法思路,关键在于灵活应用,就可做出许多特殊效果来,如把菜单项由文本换成图象,效果将大不一样;把边框线的 颜色改一下,就可获得象Dreamweaver主菜单那样,当鼠标在菜单项上时,产生凹下去的效果。

原文链接: http://blog.csdn.net/vanessa219/article/details/2174405

转载于:https://my.oschina.net/chen106106/blog/44348

巧用CSS的Border属性制作特效菜单相关推荐

  1. 巧用CSS的Border属性

    . 作者:冯永曜 来源:黄山村夫 制作过网页的人都有为画线而烦恼的经历,本文介绍的小技巧也许对你有所帮助.我们先来认识一下"Border"(画边框),它是CSS的一个属性,用它可以 ...

  2. 巧用css的border属性完成对图片编辑功能的性能优化

    一.需求场景: 最近闲来无事,boss提出了一个要求,研究相关代码并完成一个关于编辑图片功能的性能优化,该功能的主要界面展示如下: 通过了几分钟的短暂试用,发现就是一个简单的裁剪并保存用户选择并上传的 ...

  3. border属性 php,使用CSS的border属性构建变形边框的方法总结

    border是最常用的用来制作各种各样p边框的CSS属性,这里我们整理了使用CSS的border属性构建变形边框的方法总结,最主要的还是基于三角形的一些图形变换: border基础回顾border 顾 ...

  4. css边框(border)属性

    border属性 代码如下: border:边框宽度 边框风格 边框颜色; 如:border:5px solid #555; 属性: (1)边框宽度: border-width:5px; (2)边框颜 ...

  5. border属性 php,如何通过CSS的border属性为图片设置边框效果

    如何为通过css为图片设置一个边框呢,HTML中是通过标记的border属性值,给图片添加边框的,css中是通过border属性,为图片设置各式各样的边框样式,border-style定义边框的样式, ...

  6. HTMLCSS学习笔记(二十四)——利用border属性制作太极图与哆啦A梦

    旋转太极图 <!DOCTYPE html> <html lang="en"> <head><meta charset="UTF- ...

  7. 舞动你的文字,巧用CSS中marquee属性

    语法:<marquee> -</marquee> 使用移动属性marquee,不仅仅可以舞动你的文字,还可以应用于图片,表格等等. <marquee direction= ...

  8. CSS:不可思议的border属性

    原文:Magic of CSS border property 译文:不可思议的CSS border属性 译者:dwqs 在CSS中,其border属性有非常多的规则. 对于一些事物,比如三角形或者其 ...

  9. CSS属性详解——使用border属性设置边框

    CSS 是一种用于网页布局控制的语言,其中 border 属性用于为网页元素设置边框样式.颜色和宽度等.在本文中,我们将深入介绍 border 属性的详细语法和使用方式,帮助您轻松掌握使用. bord ...

最新文章

  1. 处理字符串时常用方法0914
  2. 英雄联盟离线更新方法
  3. 解决高并发的问题python_python ---解决高并发超卖问题
  4. stm32 stm8 产品型号
  5. 自动生成小学四则运算题目
  6. 快速突破面试算法之二分查找篇
  7. SAP ABAP开发从入门到精通——第15章 面向对象ALV
  8. STM32单片机(二).STM32系列单片机的介绍
  9. python3.8安装cartopy使用报错:DLL load failed while importing trace
  10. 计算机的学情分析报告,计算机教学计划合集总结5篇
  11. 8cm等于多少像素_1寸照片尺寸是多少,对应的像素是多少
  12. HDOJ 最小长方形 1859
  13. Android UI设计经验分享,掌握设计技巧,让你的应用独树一帜
  14. w7系统怎么开启打印机服务器,W7系统如何开启打印机服务
  15. 创建visio的形状
  16. 解决忘记密码报错ERROR 1044 (42000): Access denied for user ‘‘@‘localhost‘ to database ‘mysql‘的办法
  17. 照片恢复软件哪个好用?5个好用的照片恢复软件推荐
  18. python编写会计凭证金蝶_如何在金蝶财务软件中录入会计凭证
  19. chrome无法安装插件问题的解决
  20. 使用Docker离线安装包安装Docker

热门文章

  1. 一文读懂Meta Space
  2. Django 高并发负载均衡
  3. 淘宝、1688代购系统;微信代购小程序,代购系统源代码,PHP前端源码演示
  4. 手写华为商城前端页面
  5. WNetAddConnection2返回错误码1326的问题
  6. java计算机毕业设计高校网上报销系统MyBatis+系统+LW文档+源码+调试部署
  7. fmt函数linux,Linux驱动开发——pr_fmt的用法
  8. 中国人被美国老太太忽悠(转)
  9. 关于深度学习人工智能模型的探讨(三)(5)
  10. 地磅称重无人值守称重系统:全套如何选择和功能介绍