【问题标题】:Chrome is outputting something different than other browsers/IDEChrome 输出的内容与其他浏览器/IDE 不同
【发布时间】:2017-09-30 01:45:45
【问题描述】:

问题

我正在为 FreeCodeCamp 制作一个维基百科查看器。当我使用 Jetbrains Webstorm IDE 执行我的代码时,我在搜索结果的末尾总共创建了 10 个额外的 div。

当我使用 JSfiddle 这样做时,我看到了正确的结果,它应该只是最初的 10 个搜索结果,而不是 +10 个空 div 容器。

知道发生了什么吗?

疑难解答

在深入研究之后,这似乎更像是浏览器问题而不是 IDE 问题。看起来只有 Chrome 这样做?我在 Firefox 和 IE 上尝试过,它运行正常,就像 JSfiddle 一样。我也试过清除 Chrome 上的所有 cookie 和缓存。

当我打开控制台日志查看元素时,Chrome中明显多了10个空的div,如图here.

但在 Firefox 中,相同的代码不会创建 div,如图所示here.

编辑:好的,所以在 Chrome 中,如果您按 Enter 键,而不是单击搜索按钮,它会创建额外的 div。但是,如果您单击搜索图标,则结果会正确显示。谁能解释为什么?我是否错误地放置/写入了.keyup() 代码块?

这是issue.的照片

Javascript 部分:

$(function(){
$("#search-bar").keyup(function(event) {
    if(event.keyCode === 13) {
        $(".btn").click();
    }
});
$(".btn").click(function() {
    $("#results").empty();
    var searchTerm = $("#search-bar").val();
    var url = "https://en.wikipedia.org/w/api.php?action=query&list=search&srsearch=" + searchTerm + "&utf8=&format=json&origin=*";
    console.log(url);
    $.ajax({
        cache: false,
        url: url,
        type: 'GET',
        success: function(data) {
            // Create a blank array to store the specific URLs in
            var urlArr = [];
            for (var i=0; i <= data.query.search.length; i++) {
                // Adding the variables for use here
                var headerData = data.query.search[i].title;
                var urlSearchTerm = headerData.replace(/\s/gi, '_');
                var snippetData = data.query.search[i].snippet + "...";
                var createDiv = document.createElement("div");
                var createHeader = document.createElement("h1");
                var createSnippet = document.createElement("p");
                var divId = "div" + i.toString();
                var headerId = "header" + i.toString();
                var snippetId = "snippet" + i.toString();
                var resultUrl = "https://en.wikipedia.org/wiki/";
                urlArr[i] = resultUrl + urlSearchTerm;
                // Create the div element, give it an id
                // Create <h1> element, give it an id
                // Create <p> element, give it an id
                // Give each <div> a class
                createDiv.setAttribute("id", divId);
                createHeader.setAttribute("id", headerId);
                createSnippet.setAttribute("id", snippetId);
                createDiv.setAttribute("class", "each-result");
                // appending <div> elements in the #results id element in body
                // appending <h1> element to the div element
                // appending <p> element to the div element
                document.getElementById("results").appendChild(createDiv);
                document.getElementById(divId).appendChild(createHeader);
                document.getElementById(divId).appendChild(createSnippet);
                // populate json data into <h1> element
                // populate json data into <p> element
                $("#header" + i.toString()).text(headerData);
                $("#snippet" + i.toString()).html(snippetData);
                // create a click event handler that does 2 things
                // 1. Gives each div an element that has a URL in the resultUrl array
                // 2. Opens that url in a new window
                (function(i) {
                    $("#div" + i.toString()).click(function() {
                        window.open(urlArr[i]);
                });
                }(i));



            }
        }
    });

});

$("#random-wiki-button").click(function() {
   window.open("https://en.wikipedia.org/wiki/Special:Random");
});

});

包含html/css + JS的实际完整代码:JSfiddle

【问题讨论】:

    标签: javascript html css google-chrome


    【解决方案1】:

    也许尝试更新 chrome?

    我会尝试将您的 for 循环更改为 for (var i=0; i &lt; 10; i++) {,这样增量会在第 10 项停止。

    已编辑。

    【讨论】:

    • 我确实检查了它是否是最新的,并且确实如此。我还发现问题源于单击搜索按钮与输入搜索词后按 Enter 的差异。点击回车会创建更多的 div,但点击搜索不会。只在 Chrome 上……太奇怪了。
    • 您可以尝试将$(".btn").click(function() { 改为function getResults(){ your click function } 并在搜索栏HTML 和#searchbar 函数上使用onclick="getResults()"。
    猜你喜欢
    • 1970-01-01
    • 2021-12-08
    • 2013-11-02
    • 2016-09-08
    • 2011-07-31
    • 1970-01-01
    • 2011-03-28
    • 2012-04-08
    • 2017-09-05
    相关资源
    最近更新 更多