Użycie jQuery, ustawienie Przeciąganie na elemencie zapobiega wypalaniu po kliknięciu elementu przeciągalnego
Używając jQuery, gdy ustawisz zdarzenie rozmycia w polu tekstowym i ustawisz inny element jako przeciągalny, po kliknięciu elementu przeciągania zdarzenie rozmycia nie uruchomi się w FireFox. IE jest trochę lepszy, dostajesz zdarzenie rozmycia, ale nie dostajesz zdarzenia click na elemencie przeciągania.
Jeśli nie określisz cancel: "" w przeciągalnym konstruktorze, uruchomisz zdarzenie rozmycia, ale wtedy element, który chcesz przeciągnąć, nie jest przeciągalny.
jQuery v1.3.2 jQuery UI v1.7.2
Linie console.log są przeznaczone dla wtyczki FireFox FireFoxa.
<HTML>
<HEAD>
<TITLE>Blur/Click Workbench</TITLE>
<script src="js/jquery.js" type="text/javascript" ></script>
<script src="js/ui/ui.core.js" type="text/javascript"></script>
<script src="js/ui/ui.draggable.js" type="text/javascript"></script>
<script type="text/javascript">
function blurring() {
console.log('1 - blurring - ' + $( this ).attr('id'));
}
function clicking() {
console.log('2 - clicking - ' + $( this ).attr('id'));
}
$(document).ready(function() {
$( ".draggableTool" ).draggable( { cancel: "" } );
$( '.property' ).blur( blurring );
$( '#labelContainer' ).click( clicking );
});
</script>
</HEAD>
<BODY>
<input type='text' class='property' id='tb1' />
<br />
<input type='text' class='property' id='tb2' />
<br />
<label class='draggableTool' id='labelContainer' style='height:20px;position:absolute;'>
<textarea id='taLabel' style='height:100%;background-color:white;border:1px solid grey;'>Label</textarea>
</label>
</BODY>
</HTML>