多くのコードが動作せず、どこに問題があるのかを特定しようとしているのですが、console.log()
がChrome開発ツールに結果を記録していません。
$(window).scroll(function() {
$('section').each(function(){
var id='#'+$(this).attr('id'),
off=$(id).offset().top,
hei=$(id).height(),
winscroll=$(window).scrollTop(),
dif=hei+off-($(window).height());
if (winscroll >= off && winscroll<=dif) {
console.log('first broken');
$(id+' .sticky').removeClass('abs').addClass('fix');
} else if (winscroll > dif){
console.log('second broken');
$(id+' .sticky').removeClass('fix').addClass('abs');
} else {
console.log('third broken');
$(id+' .sticky').removeClass('fix abs');
} });
});
編集 フルコードを追加しました。
$(document).ready(function() {
// If a browser supports 3D transforms use the fancy menu if it doesn't, use standard accordion menu instead
if($('html').hasClass('csstransforms3d')){
$( "#mp-menu" ).removeClass( "snap-drawers" ).addClass( "mp-menu" );
$('nav ul li ul').css('border-bottom','1px solid rgba(255, 255, 255, .05)');
$('nav ul li ul').css('background','none');
// Insert elements where necessary to create the right structure
$('#mp-menu').wrapInner('<div class="mp-level" />');
$('#mp-menu').find('li > ul').wrap('<div class="mp-level" />');
$("#mp-menu ul li .mp-level").prepend(function () {
return '<span class="menu-title">' + $(this).prev().text() + '</span> <a class="ico mp-back" href="#">Back</a>';
});
// load in necessary JS files
$.getScript('http://176.32.230.2/baodev.com/cjo/wp-content/themes/CJO/js/multi-level-menu.js');
} else {
// load in necessary JS files
$.getScript( "http://176.32.230.2/baodev.com/cjo/wp-content/themes/CJO/js/jquery.navgoco.min.js", function() {
$("#demo1").navgoco({accordion: true});
});
$.getScript( "http://176.32.230.2/baodev.com/cjo/wp-content/themes/CJO/js/snap.min.js", function() {
// Snapper settings
var snapper = new Snap({
element: document.getElementById('scroller'),
disable: 'right',
maxPosition: 291
});
var addEvent = function addEvent(element, eventName, func) {
if (element.addEventListener) {
return element.addEventListener(eventName, func, false);
} else if (element.attachEvent) {
return element.attachEvent("on" + eventName, func);
}
};
// Toggle button
addEvent(document.getElementById('trigger'), 'click', function(){
if( snapper.state().state=="left" ){
snapper.close();
$( ".menu-trigger" ).removeClass( "active" );
} else {
snapper.open('left');
$( ".menu-trigger" ).addClass( "active" );
}
});
addEvent(document.getElementById('scroller'), 'click', function(){
if( snapper.state().state=="left" ){
$( ".menu-trigger" ).removeClass( "active" );
}
});
/* Prevent Safari opening links when viewing as a Mobile App */
(function (a, b, c) {
if(c in b && b[c]) {
var d, e = a.location,
f = /^(a|html)$/i;
a.addEventListener("click", function (a) {
d = a.target;
while(!f.test(d.nodeName)) d = d.parentNode;
"href" in d && (d.href.indexOf("http") || ~d.href.indexOf(e.host)) && (a.preventDefault(), e.href = d.href)
}, !1)
}
})(document, window.navigator, "standalone");
});
} // end if
fitHeight();
$(window).scroll(function() {
$('section').each(function(){
var id='#'+$(this).attr('id'),
off=$(id).offset().top,
hei=$(id).height(),
winscroll=$(window).scrollTop(),
dif=hei+off-($(window).height());
console.log('msj');
if (winscroll >= off && winscroll<=dif) {
$(id+' .sticky').removeClass('abs').addClass('fix');
} else if (winscroll > dif){
$(id+' .sticky').removeClass('fix').addClass('abs');
} else {
$(id+' .sticky').removeClass('fix abs');
}
});
});
});
// Trigger FitHeight on browser resize
$(window).resize(fitHeight);
EDIT
完全なコード(上記)の一部は他のJSファイルを参照しており、これらのファイルが存在する状態でコードを実行してもエラーは返されません。トラブルシューティングの後、スクロール関数の前にコンソールメッセージが表示されますが、スクロール関数内にコンソールメッセージが表示されません。
fitHeight();
console.log('About to bind scroll effects'); // I SEE THIS MESSAGE
$(window).scroll(function() {
console.log("scroll bound, now loop through sections"); //BUT NOT THIS ONE
$('section').each(function(){
JavaScriptのログを隠しているか、エラーや警告のみを表示するように指定しているようです。Chromeのデベロッパーツールを開き、「コンソール」タブを開きます。一番下にある「JavaScript」にチェックが入っていることを確認し、さらに「すべて」、「ログ」、「デバッグ」のいずれかが選択されていることを確認します。
.
上の画像では、JavaScript、Network、Logging、CSS、Otherにチェックを入れ、"All"を選択しています。
もうひとつの問題は、$(window).scroll()
関数が.ready()
関数にラップされていないことです(ドキュメントこちら)。
$(document).ready(function() {
$(window).scroll(function() {
...
});
});
あなたのコードをJSFiddleに貼り付けて、ダミーのコンテンツを与えてみると、あなたのコードは全く問題なく動作します。[JSFiddleのデモ][3]。
質問を編集しました。与えられた新しいコードは2つのエラーを発生させます。
Uncaught ReferenceError: fitHeight is not defined Uncaught TypeError:Cannot read property 'addEventListener' of null
このため、コードは console.log
の呼び出しに到達する前に実行を停止します。
私はこのことについて少し愚かに感じていますが、これを皆さんに教訓として伝えたいと思います...正しいセレクターをターゲットにすることを確認してください
基本的にコンソールは何も記録していませんでした。なぜなら、この特定のコードスニペットはウィンドウのスクロール領域を取得しようとしていたのですが、実際には私のコードは代わりにDIV全体をスクロールするように別の設定をしていたからです。これを変更するとすぐに
$(window).scroll(function() {
をこのように変更しました。
$('#scroller').scroll(function() {
コンソールに正しいメッセージが記録されるようになりました。
正しく行う」ということに対して、より現実的なアプローチを考えてみましょう。
console.log("about to bind scroll fx");
$(window).scroll(function() {
console.log("scroll bound, loop through div's");
$('div').each(function(){
これらの log
が両方とも正しく出力されている場合、問題は var 宣言にあると思われます。 それをデバッグするには、それを複数の行に分けることを考えてください。
var id='#'+$(this).attr('id');
console.log(id);
var off=$(id).offset().top;
var hei=$(id).height();
var winscroll=$(window).scrollTop();
var dif=hei+off-($(window).height());
こうすることで、少なくともデバッグ中には、varのid
が未定義であることがわかり、コードの残りの部分でエラーが発生する可能性があります。 もしかして、div
タグの中にid'がないものがあるのでしょうか?