Je veux utiliser CSS pour montrer div id='b'
quand je survole div id='a'
, mais je n'arrive pas à comprendre comment le faire car le div 'a'
est dans un autre div
que div 'b'
n'est pas dans.
<div id='content'>
<div id='a'>
Hover me
</div>
</div>
<div id='b'>
Show me
</div>
nous pouvons juste montrer la même étiquette div en stationnaire comme ça
<style>
#b {
display: none;
}
#content:hover~#b{
display: block;
}
</style>
C'est en effet possible avec le code suivant
<div href="#" id='a'>
Hover me
</div>
<div id='b'>
Show me
</div>
et css
#a {
display: block;
}
#a:hover + #b {
display:block;
}
#b {
display:none;
}
Maintenant, en survolant l'élément #a, l'élément #b est affiché.
Vous pouvez utiliser ax sélecteurs pour cela.
Il y a deux approches:
<
)#a:hover < #content + #b
Cette règle de style ax sélectionnera #b
, qui est le frère immédiat de #content
, qui est le parent immédiat de #a
qui a un :hover
Etat.
div {
display: inline-block;
margin: 30px;
font-weight: bold;
}
#content {
width: 160px;
height: 160px;
background-color: rgb(255, 0, 0);
}
#a, #b {
width: 100px;
height: 100px;
line-height: 100px;
text-align: center;
}
#a {
color: rgb(255, 0, 0);
background-color: rgb(255, 255, 0);
cursor: pointer;
}
#b {
display: none;
color: rgb(255, 255, 255);
background-color: rgb(0, 0, 255);
}
#a:hover < #content + #b {
display: inline-block;
}
<div id="content">
<div id="a">Hover me</div>
</div>
<div id="b">Show me</div>
<script src="https://rouninmedia.github.io/axe/axe.js"></script>
\
)#a:hover \ #b
Cette règle de style ax sélectionnera #b
, présent dans le même document que #a
qui a un :hover
Etat.
div {
display: inline-block;
margin: 30px;
font-weight: bold;
}
#content {
width: 160px;
height: 160px;
background-color: rgb(255, 0, 0);
}
#a, #b {
width: 100px;
height: 100px;
line-height: 100px;
text-align: center;
}
#a {
color: rgb(255, 0, 0);
background-color: rgb(255, 255, 0);
cursor: pointer;
}
#b {
display: none;
color: rgb(255, 255, 255);
background-color: rgb(0, 0, 255);
}
#a:hover \ #b {
display: inline-block;
}
<div id="content">
<div id="a">Hover me</div>
</div>
<div id="b">Show me</div>
<script src="https://rouninmedia.github.io/axe/axe.js"></script>