Ich versuche, die globale Variable finish
von false
in true
mithilfe des click-Ereignisses zu ändern, um das Schweben der Kreise zu verhindern. Nachdem ich Click-Ereignis verwendet habe, änderte sich meine globale Variable finish
nicht (es ist immer noch false
) und ich kann immer noch über einige Kreise schweben. Warum passiert das?Variable kann nicht geändert werden, indem ein click -Ereignis mit jQuery verwendet wird
var finish = false;
$(".rating-circle").click(function() {
$(this).addClass("rating-chosen");
$(this).prevAll().addClass("rating-chosen");
finish = true;
});
if (finish == false)
{
$(".rating-circle").hover(
\t function() {
$(this).addClass("rating-hover");
$(this).prevAll().addClass("rating-hover");
},
function() {
$(this).removeClass("rating-hover")
$(this).prevAll().removeClass("rating-hover");
});
}
body {
font-family: Verdana;
}
h1, h2, h3 {
color: darkblue;
}
.rating-circle {
height: 2em;
width: 2em;
border: .1em solid black;
border-radius: 1.1em;
display: inline-block;
margin: 0;
padding: .1em;
}
.rating-hover {
background-color: yellow;
}
.rating-chosen {
background-color: green;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<h2>Finding elements using jQuery</h2>
<h3>Rate this session</h3>
<div id="rating-container">
<div class="rating-circle"></div>
<div class="rating-circle"></div>
<div class="rating-circle"></div>
<div class="rating-circle"></div>
<div class="rating-circle"></div>
</div>