Я знаю, что есть и другие сообщения, подобные этому, но я хотел спросить, может быть, проблема в моем коде Jquery.
Chrome, Firefox, даже IE 10+ работают без сбоев при таком подходе. Safari очень тормозит, и я думаю, что это может быть jquery. Потому что для обновления значения "top:" требуется некоторое время. Не уверен, что может быть причиной этого.
Вот Jquery:
$(document).scroll(function() {
var windowSize = $(window).width();
if (windowSize > 1019) {
if ($(document).scrollTop() > 380) {
if ($('.sub-nav').closest('.standard-content').height() > ($(document).scrollTop() + $('.sub-nav').outerHeight()+70)){
$('.sub-nav').css('top', $(document).scrollTop() - 400);
}
}
else {
$('.sub-nav').css('top', 0);
}
}
});
CSS:
.side-nav {
height: 100%;
position: relative;
width: 100%;
}
.sub-nav {
-webkit-transform: translate3d(0, 0, 0);
transform: translate3d(0, 0, 0);
left: 0;
position: absolute;
top: 0;
width: 100%;
-webkit-backface-visibility: hidden;
backface-visibility: hidden;
@include transition(top, .1s, linear);
}
HTML:
<div class="sidebar match-height">
<aside>
<h3>Sub-menu title</h3>
<div class="side-nav">
<ul class="sub-nav">
<li><a href="#">Menu item</a></li>
<li><a href="#">Menu item</a></li>
<li><a href="#">Menu item</a>
<ul>
<li><a href="#">Sub-menu item</a></li>
<li><a href="#">Sub-menu item</a></li>
<li><a href="#">Sub-menu item</a></li>
</ul>
</li>
<li><a href="#">Menu item</a></li>
<li><a href="#">Menu item</a></li>
</ul>
</div>
</aside>
</div>
Анимация в сафари очень плохая... Не знаю почему. Как я уже говорил, все остальные браузеры работают нормально. Возможно, причиной отставания является мой JQuery. CSS Я пробовал все с -webkit-backface-visibility: hidden; -webkit-transform: translate3d(0, 0, 0); и т.д...
Заранее спасибо.