将响应菜单重写为仅css
rewrite responsive menu to css only
我有菜单:
JSFIDLE
jsfidle
HTML
<a class="toggleMenu" href="#"><img src="img/icon-menu.png" alt=""></a>
<ul class="menu">
<li class="first activeSelected"><a href="#">Homepage</a></li>
<li><a href="#">About Us</a></li>
<li><a href="#">Services</a>
<ul class="level1">
<li class="first"><a href="#">Fitness</a></li>
<li class="last"><a href="#">Sport and relax</a></li>
</ul>
</li>
<li><a href="#">News</a></li>
<li class="last"><a href="#">Contact Us</a></li>
</ul>
CSS
/* MENU */
.menu {
margin: 0;
padding: 0;
}
.menu a {
text-decoration: none;
}
.toggleMenu {
display: none;
padding: 9px 9px 6px 9px;
margin: 0px 0 0 2px;
color: #000;
background: #00a1ba;
border: 1px #00a1ba solid;
}
.menu {
list-style: none;
*zoom: 1;
z-index: 99;
}
.menu:before,
.menu:after {
content: " ";
display: table;
}
.menu:after {
clear: both;
}
.menu ul {
list-style: none;
width: 9em;
}
.menu a {
padding: 10px 15px;
color: #848484;
}
.menu a:hover {
background: #0093aa;
}
.active {
color: #fff;
background: #0093aa;
}
.menu li {
position: relative;
}
.menu > li {
float: left;
background: #fff;
}
.menu > li:hover {
background: #0093aa;
}
.menu > li:hover a {
color: #fff;
}
.menu > li > .parent {
/*background-image: url("../img/downArrow.png");*/
background-repeat: no-repeat;
background-position: right;
}
.menu > li > a {
display: block;
}
.menu li ul {
position: absolute;
left: -9999px;
}
.menu > li.hover > ul {
left: 0;
}
.menu li li.hover ul {
left: 100%;
top: 0;
}
.menu li li a {
display: block;
background: #00a1ba;
color: #fff;
position: relative;
z-index: 100;
border-top: 1px solid #0093aa;
}
.menu li li li a {
background: #00a1ba;
color: #fff;
z-index:200;
border-top: 1px solid #0093aa;
}
@media screen and (max-width: 640px) {
.menu {
position: absolute;
right: 0;
text-align: center;
}
.active {
display: block;
}
.menu > li {
float: none;
background: #00a1ba;
border-top: 1px solid #0093aa;
max-width: 280px;
min-width: 200px;
}
.menu > li:hover {
background: #0093aa;
}
.menu > li > a {
color: #fff;
}
.menu > li > .parent {
background-position: 95% 50%;
}
.menu li li .parent {
/*background-image: url("../img/downArrow.png");*/
background-repeat: no-repeat;
background-position: 95% 50%;
}
.menu ul {
display: block;
width: 100%;
}
.menu li li a:hover {
background: #0093aa;
}
.menu > li.hover > ul , .menu li li.hover ul {
position: static;
}
}
JS
var ww = document.body.clientWidth;
$(document).ready(function() {
$(".menu li a").each(function() {
if ($(this).next().length > 0) {
$(this).addClass("parent");
}
;
})
$(".toggleMenu").click(function(e) {
e.preventDefault();
$(this).toggleClass("active");
$(".menu").toggle();
});
adjustMenu();
})
$(window).bind('resize orientationchange', function() {
ww = document.body.clientWidth;
adjustMenu();
});
var adjustMenu = function() {
if (ww < 640) {
$(".toggleMenu").css("display", "inline-block");
if (!$(".toggleMenu").hasClass("active")) {
$(".menu").hide();
} else {
$(".menu").show();
}
$(".menu li").unbind('mouseenter mouseleave');
$(".menu li a.parent").unbind('click').bind('click', function(e) {
// must be attached to anchor element to prevent bubbling
e.preventDefault();
$(this).parent("li").toggleClass("hover");
});
}
else if (ww >= 640) {
$(".toggleMenu").css("display", "none");
$(".menu").show();
$(".menu li").removeClass("hover");
$(".menu li a").unbind('click');
$(".menu li").unbind('mouseenter mouseleave').bind('mouseenter mouseleave', function() {
// must be attached to li so that mouseleave is not triggered when hover over submenu
$(this).toggleClass('hover');
});
}
}
问:
如何在没有JS的情况下执行悬停和嘟嘟声?
这是一个仅CSS的例子,它向您展示了您所说的的HOVER效果
小提琴
将鼠标悬停在"程序"链接上并选中它。这种效果可以应用于HTML 中的任何元素
CSS语法如下
Element_name:Hover{
// CSS code
}
示例:
img{
opacity:1;
}
img:hover{
opacity:0;
}
上面的例子将使img在悬停时透明。
如何在没有JS的情况下悬停和嘟嘟?
有一个:hover
伪类,您可以在CSS选择器中使用它。
若要进行切换,可以仅将display:none;
应用于元素,也可以不应用。
使用纯CSS不能做的是响应click
事件。你需要JS。
对于多级,您可以尝试这个
http://jsfiddle.net/cancerian73/gAMVM/
body {
background: #ccc;
font-family: helvetica, arial, serif;
font-size: 13px;
text-transform: uppercase;
text-align: center;
}
相关文章:
- 重写CSS:使用jquery显示none属性
- css中的url用angular重写
- 如何动态创建可被早期规则重写的css样式规则
- 使用Javascript而不是css重写bootstrap maxWidth
- 重写HTML CSS元素
- 用jQuery重写内联CSS
- 如果我在 javascript 中重写了类名,是否重新应用了现有的 CSS 属性
- 如何正确地缩小/组合网页项目中的CSS/JS与url重写
- IIS重写规则,将querystring添加到ASP.net页面中的.css和.js引用中
- 如何在没有jquery元素的情况下重写css规则
- 将响应菜单重写为仅css
- 在.htaccess中设置URL重写规则后javascript文件和css文件的路径
- 使用JavaScript可以同时用类和标记重写CSS
- IIS URL重写CSS URL()值时出现问题
- 元素中生成的Css.样式正在影响我的网页,我无法重写
- 是否有可能在js中重写CSS ?
- 如何使用javascript/angularJs应用/防止覆盖/重写css/样式
- jQuery's的CSS方法重写:hover属性
- 在响应问题上重写css元素
- htaccess重写整个网页的html标记的规则、CSS和JS文件