Я не могу понять, почему .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);
});
}
Какая ошибка ..? – fzxt
Возможно, вы захотите отключить событие отправки формы. '' '$ ('. searchBar form'). on ('submit', function (e) {e.preventDefault(); return false;});' '', чтобы избежать отправки формы при нажатии пользователем. Также проверьте, имеет ли ответ ключ '' 'query''' перед добавлением данных в тело. – LucasFerreira
@ LucasFerreira Спасибо, избегая отправки формы при нажатии кнопки, сделал трюк. – CodingerSK