具有不同输入速度的嵌套 AJAX

Nested AJAX with different input speed

本文关键字:嵌套 AJAX 输入速度      更新时间:2023-09-26

我在求职面试中遇到了这个Ajax问题:

我们有这段代码,其中onChange进行AJAX调用(对asdf服务器),它也进行另一个AJAX调用(对qwer服务器),

 function onDescription(description) {
    var content = $('').text(description);
    $('#results').append(content);
}
    function onSearchResults(searchResults){
        $('#results').html('');
        $.each(searchResults, function(result){
            $.ajax({
                url: 'http://qwer.com/describe',
                dataType: 'json',
                data: result,
                success: onDescription
            });
        });
    }
    function onChange(){
        $.ajax({
            url:'http:://asdf.com/search',
            dataType: 'json',
            data: $('#search').val(),
            success: onSearchResults
        });
    }
$('#search').keydown(onChange);

问题是:如果用户以不同的速度输入文本会发生什么。

1- ASDF 服务器将过载2-当用户非常快速地输入文本时,将不会显示来自qwer的描述3-将显示预览搜索结果而不是当前结果4-在向ASDF请求之前显示来自qwer的当前搜索查询的描述

对我来说,甚至选择也不是很清楚。那么在您看来,如果我们有一个嵌套的 AJAX 调用和不同的输入速度会发生什么?

以上

都不是。AJAX 被设计为不是确定性的。如果用户开始键入"moon",将向 asdf 发送四个请求:"m"、"mo"、"moo"和"moon"。但是结果返回的顺序是不确定的。服务器可能需要不同的时间来响应每个请求。您可以按"moo","m","moon","mo"的顺序获得响应。随着打字速度的变化,结果可能会发生变化,但这取决于

安全的做法是忽略先前查询的结果。这是一个快速解决方案:

function onDescription(description) {
    var content = $('').text(description);
    $('#results').append(content);
}
var searchResultQuery = '';
function onSearchResults(query){
    searchResultQuery = query;
    return (function(query) {
        return function(searchResults) {
            if (query != searchResultQuery) {
                return;
            }
            $('#results').html('');
            $.each(searchResults, function(result){
                $.ajax({
                    url: 'http://qwer.com/describe',
                    dataType: 'json',
                    data: result,
                    success: onDescription
                });
            });
        };
    })(query);
}
function onChange(){
    $.ajax({
        url:'http:://asdf.com/search',
        dataType: 'json',
        data: $('#search').val(),
        success: onSearchResults($('#search').val())
    });
}
$('#search').keydown(onChange);