编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu_经验交流
Freigeben: 2016-05-16 12:08:46
Original
5229 Leute haben es durchsucht
-
编写纯 CSS 弹出菜单的原理及实现 By shawl.qiu
摘要:
本文介绍了使用 CSS 编写适用于 Opera, Firefox, IE 的多风格弹出菜单
说明:
编写 CSS 弹出菜单的要点不外乎当鼠标移到目标上时, 显示出隐藏的标签.
要隐藏的标签使用 display:none; 属性进行隐藏.
触发显示隐藏标签主要使用 :hover 属性, 并用 display:block; 显示隐藏的标签.
但由于浏览器对 CSS 的支持并非一致.
对于 Opera 或者 Firefox, 我们可以编写出纯 CSS 菜单, 他们支持任何标签的 :hover 属性.
而对于 IE 浏览器, :hover 只对 a 标签起作用, 但我们可以使用脚本的 onmouseover, onmouseout 模拟出其他标签的 :hover 属性.
因此编写适用于 IE 的 CSS 弹出菜单必须使用到少许的脚本.
目录:
1. 编写直排右侧弹出的 CSS 菜单.
1.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
2. 编写横排底部弹出的 CSS 菜单.
2.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
3. 结论
4. 预览
shawl.qiu
2006-10-01
http://blog.csdn.net/btbtd
1. 编写直排右侧弹出的 CSS 菜单.
1.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
linenum
- nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
-
-
-
-
Untitled Document
-
-
-
-
-
-
-
1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
linenum
- nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
-
-
-
-
Untitled Document
-
-
<script>
<LI>//<![CDATA[
<LI>if (navigator.appName=="Microsoft Internet Explorer") {
<LI> function fPmVerticalRightOut() {
<LI> var getItem = document.getElementById("pmVerticalRightOut").getElementsByTagName("div");
<LI> for (var i=0; i<getItem.length; i++) {
<LI> getItem[i].onmouseover=function() {
<LI> if( this.className=="level"){
<LI> this.className="levelIe";
<LI> }
<LI> }
<LI> getItem[i].onmouseout=function() {
<LI> if( this.className=="levelIe"){
<LI> this.className="level";
<LI> }
<LI> }//css popup menu script by shawl.qiu
<LI> }
<LI> }
<LI> window.onload=fPmVerticalRightOut;
<LI>}
<LI>//]]>
<LI></script>
-
-
-
-
-
-
2. 编写横排底部弹出的 CSS 菜单.
2.1 真正的基于 Opera, Firefox 纯 CSS 弹出菜单
linenum
- nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
-
-
-
-
Untitled Document
-
-
-
-
-
-
-
2.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现)
linenum
- nbsp;HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
- " http://www.w3.org/TR/html4/loose.dtd">
-
-
-
-
Untitled Document
-
-
<script>
<LI>//<![CDATA[
<LI>if (navigator.appName=="Microsoft Internet Explorer") {
<LI> function fPmHorizontalBottomOut() {
<LI> var getItem = document.getElementById("pmHorizontalBottomOut").getElementsByTagName("div");
<LI> for (var i=0; i<getItem.length; i++) {
<LI> getItem[i].onmouseover=function() {
<LI> if( this.className=="level"){
<LI> this.className="levelIe";
<LI> }
<LI> }
<LI> getItem[i].onmouseout=function() {
<LI> if( this.className=="levelIe"){
<LI> this.className="level";
<LI> }
<LI> }//css popup menu script by shawl.qiu
<LI> }
<LI> }
<LI> window.onload=fPmHorizontalBottomOut;
<LI>}
<LI>//]]>
<LI></script>
-
-
-
-
-
-
3. 结论
以上例子可以看出, 如果已经编写出一个可用的CSS弹出菜单例子, 那要编写出弹出位置在其他地方的 CSS 弹出菜单的话, 只须小小修改一下就 OK.
4. 预览
4.1 1.2 兼容 IE, Opera, Firefox 的 CSS 弹出菜单(脚本实现) 的预览
-
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
-
2024-10-22 09:46:29
-
2024-10-13 13:53:41
-
2024-10-12 12:15:51
-
2024-10-11 22:47:31
-
2024-10-11 19:36:51
-
2024-10-11 15:50:41
-
2024-10-11 15:07:41
-
2024-10-11 14:21:21
-
2024-10-11 12:59:11
-
2024-10-11 12:17:31