我正在尝试在将鼠标悬停在div(id =“above”)上时更改身体的背景图像/渐变,我按照他们在另一篇文章中的方式进行操作(http://stackoverflow.com/questions/ 1462360 / css-hover-one-element-effect-for-multiple-elements)但它似乎不起作用
CSS
body {
background: -webkit-gradient(radial, ...);
}
.about:hover body{
background: -webkit-gradient(radial, ...); // new gradient
}
HTML
<body>
<div class="about">
<h1 id="title">About</h1>
<div>
<p id="about">stuff</p>
</div>
</div>
</body>
这没有效果,我甚至尝试通过在悬停时将标题样式更改为斜体来测试它是否有效,仍然没有用
.about:hover h1.title {
font-weight: italic;
}
这是我使用它的方式是错误还是还有别的东西,任何人都可以提供帮助?
答案 0 :(得分:1)
如果您想使用CSS(无javascript),可以使用z-index
进行操作:
请在此处查看示例:http://jsfiddle.net/nCyJ4/
或者,在您的情况下,http://jsfiddle.net/nCyJ4/1/:
HTML:
<div class="initial background" id="bg0"></div>
<div class="about bgwrapper">
<h1 id="title">About</h1>
<div>
<p id="about">stuff</p>
</div>
<div id="bg1" class="background"></div>
</div>
CSS:
.background{
position:fixed;
top:0;left:0;
width:100%;height:100%;
display:none;
z-index:-1;
}
.bgwrapper:hover>.background,.initial.background{
display:block;
}
.initial.background:hover{
display:block!important;
}
.background:hover{
display:none!important;
}
#bg0{
background: -moz-linear-gradient(left, #FF0000 0%, #FF9900 10%, #FFFF00 16.666%, #CCFF00 20%, #32FF00 30%, #00FF00 33.333%, #00FF65 40%, #00FFFF 50%, #00FFFF 50%, #0065FF 60%, #0000FF 66.666%, #3300FF 70%, #CB00FF 80%, #FF00FF 83.333%, #FF0098 90%, #FF0004 100%);
}
#bg1{
background: -moz-linear-gradient(left center, #FF0000, #000000) repeat scroll 0 0 transparent
}
答案 1 :(得分:0)
由于body
不是div.about
的后代,因此无法将其作为目标。您可以使用一些JavaScript来实现您所需的效果。
<强> CSS 强>
body {
background: -webkit-gradient(radial, ...);
}
body.hover {
background: -webkit-gradient(radial, ...); // new gradient
}
<强>的JavaScript 强>
document.getElementsByClassName('about')[0].onmouseover = function () {
document.getElementsByTagName('body')[0].className += ' hover';
}
document.getElementsByClassName('about')[0].onmouseout = function () {
var n = document.getElementsByTagName('body')[0];
n.className = n.className.replace('hover', '');
}