47

一堆代码不起作用,我试图找出问题所在,但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);

编辑

完整代码的某些部分(上图)引用了其他 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(){
4

14 回答 14

82

听起来您要么隐藏了 JavaScript 日志,要么指定只想查看错误或警告。打开 Chrome 的开发者工具并转到控制台选项卡。在底部,您要确保选中 JavaScript,并确保您选择了“全部”、“日志”或“调试”。

示例截图

在上图中,我勾选了 JavaScript、网络、日志记录、CSS 和其他,并选择了“全部”。


另一个潜在问题可能是您的$(window).scroll()函数未包含在.ready()函数中(如此所述):

$(document).ready(function() {
    $(window).scroll(function() {
        ...
    });
});

将代码粘贴到 JSFiddle 并提供一些虚拟内容时,您的代码可以正常工作:JSFiddle demo


编辑:

问题已编辑。给出的新代码引发了两个错误:

未捕获的 ReferenceError:未定义 fitHeight 未捕获的 TypeError:无法读取 null 的属性“addEventListener”

因此,代码在到达任何console.log调用之前停止执行。

于 2013-10-29T15:12:16.333 回答
78

就我而言,所有控制台消息都没有显示,因为我在“过滤器”文本框中留下了一个字符串。

通过单击 X 删除过滤器,如下所示:

在此处输入图像描述

于 2019-03-01T18:25:11.410 回答
11

我对此感到有点愚蠢,但让这对每个人来说都是一个教训......确保您选择正确的选择器!

基本上控制台没有记录任何东西,因为这个特定的代码片段试图抓取我的窗口的滚动区域,而实际上我的代码设置不同以滚动整个 DIV。我一改:

$(window).scroll(function() {

对此:

$('#scroller').scroll(function() {

控制台开始记录正确的消息。

于 2013-10-29T16:51:52.620 回答
9

单击恢复按钮。console.log将开始工作。

在此处输入图像描述

于 2020-08-30T04:45:00.607 回答
3

这是因为我之前在框列表中关闭了“日志”。在此处输入图像描述

于 2020-10-25T21:59:30.980 回答
3

2021解决方案

  • 打开开发者工具
  • 导航到“控制台”
  • 很可能没有勾选“详细”,所以激活它

在此处输入图像描述

于 2021-11-02T17:59:43.040 回答
3

在我的例子中,我正在开发一个 Polymer WebComponent,它包含<link rel="import">在主 HTML 文档中。事实证明,由于某种原因,WebComponent HTML 文件被缓存了,即使我在缓存版本之后更改了它。

为了解决这个问题,我打开了开发者控制台(在 Chrome 中),右键单击 URL 栏旁边的重新加载箭头并选择“空缓存和硬重新加载” - 问题解决了。

于 2018-01-23T16:39:27.443 回答
1

某处console.log已在某个 js 文件中被覆盖(我无法找到)。

但我可以通过放入console.log控制台进行测试,但我只有一个空函数:f{}

我将此添加到我自己的 js 文件的顶部以更正它(绝对 hack,但对我有用):

var console = window.console;
于 2021-11-13T10:14:16.947 回答
1

我刚刚遇到了同样的问题,我的控制台消息都没有显示。这仅仅是因为我在 Windows 10 上使用了新的 Edge(基于 Chromium)浏览器。它不会显示我的控制台消息,而 Chrome 会显示。我猜这是 Edge 的问题,因为 Edge 有另一个奇怪的问题,因为它以不同的方式处理带单引号和双引号的字符串。

于 2020-06-26T07:17:16.233 回答
1

只需要选择正确的选项来显示来自控制台选项卡下左侧提供的选项的日志消息。您可以参考屏幕截图。 截屏

于 2019-10-04T17:17:51.687 回答
0

考虑一个更务实的方法来解决“正确地做”的问题。

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());

通过这样做,至少在调试期间,您可能会发现 varid未定义,从而导致整个代码的其余部分出错。是否有可能您的某些div标签没有ID?

于 2013-10-29T15:26:14.923 回答
0

在我的情况下,它是由console.groupCollapsed().

并且ctrl+f显然不会检测到折叠的消息。

维护不熟悉的代码有时很可怕......

它甚至折叠了异常消息,没有它让我把那些console.logs放在首位^_^

于 2020-09-12T16:52:36.277 回答
0

作为一个 javascript 的新手,我在这里遇到了同样的问题。我犯的错误是我使用了:

<script type="text.javascript">
  console.log("bla bla bla");
</script>

代替:

<script>
  console.log("bla bla bla");
</script>

使用

类型="文本.javascript"

结果没有在控制台中生成日志。

于 2020-05-05T23:10:29.207 回答
0

如果在 html 中的 console.log 中使用 $ 参数,则单引号 (') 和双引号 ("") 将不起作用。

使用像 (` `) 这样的引号

示例:console.log(`${address}`);

这将有助于在使用$参数时以及在 console.log 中遇到问题的任何人。

于 2021-05-01T00:06:16.167 回答