私のコードは以下の通りです。このためなぜjqueryのisVisibleはスクロール機能と一緒に動作しません
$(document).ready(function() {
var scroll_start = 0;
var startchange = $('.q-intro-text');
var offset = startchange.offset();
$(document).scroll(function() {
scroll_start = $(this).scrollTop();
if (scroll_start > offset.top) {
$('#q-nav').css('background-color', 'black');
} else {
$('#q-nav').css('background-color', 'transparent');
}
});
$(document).on("scroll", onScroll);
//smoothscroll
$('a[href^="#"]').on('click', function(e) {
e.preventDefault();
$(document).off("scroll");
$('a').each(function() {
$(this).removeClass('active');
})
$(this).addClass('active');
var target = this.hash,
menu = target;
$target = $(target);
$('html, body').stop().animate({
'scrollTop': $target.offset().top + 2
}, 500, 'swing', function() {
window.location.hash = target;
$(document).on("scroll", onScroll);
var scroll_start = 0;
var startchange = $('.q-intro-text');
var offset = startchange.offset();
$(document).scroll(function() {
scroll_start = $(this).scrollTop();
if (scroll_start > offset.top) {
$('#q-nav').css('background-color', 'black');
} else {
$('#q-nav').css('background-color', 'transparent');
}
});
});
});
});
function onScroll(event) {
var scrollPos = $(document).scrollTop();
$('#q-nav a').each(function() {
var currLink = $(this);
var refElement = $(currLink.attr("href"));
if (refElement.position().top <= scrollPos && refElement.position().top + refElement.height() > scrollPos) {
$('#q-nav ul li a').removeClass("active");
currLink.addClass("active");
// $('#q-nav').css('background-color', 'red');
} else {
currLink.removeClass("active");
// $('#q-nav').css('background-color', 'transperant');
}
});
}
#q-nav {
width: 100%;
height: 8rem;
position: fixed;
top: 0;
padding-top: 3rem;
}
#q-nav ul {
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-webkit-box-orient: horizontal;
-webkit-box-direction: normal;
-ms-flex-direction: row;
flex-direction: row;
-webkit-box-pack: end;
-ms-flex-pack: end;
justify-content: flex-end;
}
#q-nav .q-nav-about {
position: relative;
color: #ffffff;
text-decoration: none;
font-weight: bold;
padding: 0rem 2rem 0 2rem;
}
#q-nav ul li {
list-style: none;
}
#q-nav .q-nav-work {
position: relative;
color: #ffffff;
text-decoration: none;
font-weight: bold;
padding: 0rem 2rem 0 2rem;
}
#q-nav .q-nav-contact {
position: relative;
font-weight: bold;
color: #ffffff;
text-decoration: none;
padding: 0rem 8rem 0 2rem;
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="format-detection" content="telephone=no">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/css/bootstrap.min.css">
<link rel="stylesheet" type="text/css" href="//fonts.googleapis.com/css?family=Open+Sans" />
<link rel="stylesheet" href="../test/css/index.css">
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
</head>
<body>
<div id="q-nav">
<ul>
<li><a class="active q-nav-about " id="is-visible" href="#about-us">ABOUT US</a>
</li>
<li><a class="q-nav-work" href="#work">WORK</a>
</li>
<li><a class="q-nav-contact" href="#contact-us">CONTACT US</a>
</li>
</li>
</ul>
</div>
</body>
、私はthis exampleを次しています。今はすべて正常に動作します。しかし、私がしたいことは、ユーザーが下にスクロールすると、ナビメニューの色が変わるはずです。これは起こっています。ユーザーが最初のページにスクロールバックすると、navメニューは自動的に透過的になります。そのために私はisVisible関数を使用していますが、何らかの形でそれが検出できない場合アクティブは可視ですか?私はそれを知ることができる他の方法がありますか?
あなたは、クリックやスクロールにしたいですか? –
いいえ、私が欲しいのは、デフォルトのnavbarは透明ですが、スクロールダウンすると黒くなり、スクロールバックすると透明になります。 –
「透明」のスペルミスがあるので、あなたのスタイリングを適用できないだけでなく、要素を選択しないという問題は本当にありますか? –