$ .getJSON()调用抛出错误

时间:2016-01-20 20:30:19

标签: javascript jquery html api getjson

我无法弄清楚为什么.getJSON在通过条件语句调用父函数时抛出错误。当if语句被注释掉时,似乎没有问题并且.getJSON被调用。但是,我希望用户完成输入(按Enter键表示)。

HTML

<div class="text-center searchBar">
  <form action="">
    <input type="text" id="searchText" />
  </form>
</div>

<div class="container displayResults"> </div>

Javascript:

$(document).ready(function() {
   $('#searchText').keyup(function(e) {
     var searchItem = $('#searchText').val();
     var link = 'https://en.wikipedia.org/w/api.php?action=query&prop=extracts|info&exintro&exlimit=max&inprop=url&generator=search&gsroffset=&format=json&formatversion=2&callback=?&gsrsearch=' + searchItem;

     if(e.which == 13) { //if user returns enter key
      wikiCall(link);
     }    
   });
});

function wikiCall(wikiLink) {  
  $.getJSON(wikiLink, function(searchResults) {      
    for (var i = 0; i < searchResults.query.pages.length; i++) {
      $(".displayResults").append("<div class='searchResultsContainer'><span style='font-weight:bold; font-size:150%; margin-bottom:100px;'>" + searchResults.query.pages[i].title + "</span><br></br>" + searchResults.query.pages[i].extract + "</div>");
      $(".displayResults").append("<br>");
    }
  }).fail(function(jqxhr,textStatus,error){
    alert(textStatus+": "+error);
  });
}

1 个答案:

答案 0 :(得分:2)

我测试了你的软件,我只得到一个错误:密钥而不是按键加停止传播。

以下代码:

&#13;
&#13;
function wikiCall(wikiLink) {
  $.getJSON(wikiLink, function(searchResults) {
    for (var i = 0; i < searchResults.query.pages.length; i++) {
      $(".displayResults").append("<div class='searchResultsContainer'><span style='font-weight:bold; font-size:150%; margin-bottom:100px;'>" + searchResults.query.pages[i].title + "</span><br></br>" + searchResults.query.pages[i].extract + "</div>");
      $(".displayResults").append("<br>");
    }
  }).fail(function(jqxhr,textStatus,error){
    alert(textStatus+": "+error);
  });
}
$(function () {
  $('#searchText').keypress(function(e) {
    var searchItem = $('#searchText').val();
    var link = 'https://en.wikipedia.org/w/api.php?action=query&prop=extracts|info&exintro&exlimit=max&inprop=url&generator=search&gsroffset=&format=json&formatversion=2&callback=?&gsrsearch=' + searchItem;

    if(e.which == 13) { //if user returns enter key
      wikiCall(link);
      e.preventDefault();
    }
  });
});
&#13;
<script src="http://code.jquery.com/jquery-1.11.3.js"></script>


<div class="text-center searchBar">
    <form action="">
        <input type="text" id="searchText" />
    </form>
</div>

<div class="container displayResults"> </div>
&#13;
&#13;
&#13;

键入字符时的事件序列是: keydown,keypress,keyup。

对于前两个事件,您可以防止,但您无法阻止在键盘事件中键入的字符。

keyup事件是你听的最后一个事件,你只能说:好吧,这是我采取行动的角色,但是我不能阻止这个角色的效果,比如表格提交。

当您键入新行时,三个事件的结果为:

keydown keyCode = 13 = 13 charCode = 0

keypress keyCode = 13 = 13 charCode = 13

keyup keyCode = 13 = 13 charCode = 0