Последующие действия после вопрос про заказ функций XHR Это рекурсивная ситуация, когда sendRequest() создает поле со ссылкой onclick на себя. Эта ссылка onclick хранит слово переменной, которое должно передаваться в sendRequest при вызове.
<script type = "text/javascript">
function inputReq(){
sendRequest(wordform.word.value)
}
function sendRequest(str){
//we start by removing the now superfluous rows
table=document.getElementById('table')
while(table.rows.length>2){
table.deleteRow(2);
}
var request = new XMLHttpRequest();
console.info('sending request');
request.open('GET', 'http://127.0.0.1:5000/api.html?query='+str, true);
request.onreadystatechange = function() {
if (request.readyState == 4) {
json=request.responseText;
console.info(json);
//json.forEach(function(obj) {
//});
for (word in json){
var row=table.insertRow();
var scoreC=row.insertCell();
var wordC=row.insertCell();
scoreC.innerHTML=json[word];
wordC.innerHTML=word;
wordC.onclick=(function(i) {sendRequest(i);})(word);
}
} else {
console.info("Silence on the line");
}
}
request.send();
}
</script>
<!DOCTYPE html>
<html>
<head>
<title>Query Page</title>
</head>
<body>
<h1>Query Page</h1>
<table id='table' style = "width:100%">
<tr><form name='wordform'>
<th>Concept: <input type = "text" name = "word"></th>
<th><input type = "button" onclick = "inputReq()" value='Find Associations'></th>
</form></tr>
</body>
</html>
Ответ XHR выглядит следующим образом:
{"milk": 1, "cheese": 3, "bread": 2}
Я следил за эта схема, но эта строка вызывает функцию вместо добавления ссылки по клику:
wordC.onclick=(function(i) {sendRequest(i);})(word);



![Безумие обратных вызовов в javascript [JS]](https://i.imgur.com/WsjO6zJb.png)


Поскольку это IIFE (выражение функции с немедленным вызовом), он вызывается мгновенно. Поместите другую функцию вокруг него.
wordC.onclick = () => (function(i) { sendRequest(i); })(word);
(Вышеупомянутое не похоже, что у него есть функция окружения, но это так — это функция стрелки ES6).
После некоторых исправлений в оставшемся коде генерируются функции onclick