Ответ 1
Здесь вы идете:
$(document).ready(function(){
$('#submenu li').hover(function(){
$('#carousel').css('background-position', '10px 10px');
}, function(){
$('#carousel').css('background-position', '');
});
});
Я хотел бы изменить исходное положение CSS-класса во время зависания li-элемента.
HTML:
<div id="carousel">
<ul id="submenu">
<li>Apple</li>
<li>Orange</li>
</ul>
</div>
CSS
#carousel {
float: left;
width: 960px;
height: 360px;
background: url(../images/carousel.png);
}
Любые предложения о том, как это сделать?
Здесь вы идете:
$(document).ready(function(){
$('#submenu li').hover(function(){
$('#carousel').css('background-position', '10px 10px');
}, function(){
$('#carousel').css('background-position', '');
});
});
Вы, ребята, усложняете вещи. Вы можете просто сделать это из CSS.
#carousel li { background-position:0px 0px; }
#carousel li:hover { background-position:100px 0px; }
$('#submenu li').hover(function(){
$('#carousel').css('backgroundPosition', newValue);
});
Устанавливает новое значение для backgroundPosition
в div carousel
, когда li в div submenu
зависает. Удаляет backgroundPosition
при наведении курсора и сбрасывает backgroundPosition
на старое значение.
$('#submenu li').hover(function() {
if ($('#carousel').data('oldbackgroundPosition')==undefined) {
$('#carousel').data('oldbackgroundPosition', $('#carousel').css('backgroundPosition'));
}
$('#carousel').css('backgroundPosition', [enternewvaluehere]);
},
function() {
var reset = '';
if ($('#carousel').data('oldbackgroundPosition') != undefined) {
reset = $('#carousel').data('oldbackgroundPosition');
$('#carousel').removeData('oldbackgroundPosition');
}
$('#carousel').css('backgroundPosition', reset);
});
Ответ на восстание выше на самом деле не будет работать, потому что для CSS "background-position" фактически сокращает "background-position-x" и "background-position-y", поэтому правильная версия его кода будет выглядеть следующим образом:
$(document).ready(function(){
$('#submenu li').hover(function(){
$('#carousel').css('background-position-x', newValueX);
$('#carousel').css('background-position-y', newValue);
}, function(){
$('#carousel').css('background-position-x', oldValueX);
$('#carousel').css('background-position-y', oldValueY);
});
});
Потребовалось около 4 часов, ударив головой о нее, чтобы прийти к этой усугубляющей реализации.