javascript - 如何将 jQuery 自动完成插件用于链接的输入字段?

标签 javascript jquery ajax autocomplete

我正在使用 jQuery Autocomplete plugin .我在表单上有两个输入字段,inputfield1inputfield2

我将自动完成附加到第一个字段。当该字段失去焦点时,我想检查是否输入了一个值,如果输入了,则进行 AJAX 调用以检索一些以“\n”分隔的字符串,并使用它们驱动第二个字段的自动完成。

下面是我用来执行此操作的代码:

/*Receive data from server for autocomplete*/
$("#inputfield1").autocomplete("<url1>"); 

$("#inputfield1").blur(function(){

    // Attach autocomplete if inputfield1 field is not empty
    if($("#inputfield1").val() != ""){
        var url = "<url2>?q="+$("#inputfield1").val();
        $.get(url,function(data){
            result=data.split("\n");
            $("#inputfield2").autocomplete(result);

        });
    }
});

但是一件奇怪的事情发生了:我能够成功地将自动完成附加到第一个字段,但是我必须将焦点两次放在第二个字段上才能在其上使用自动完成。有什么办法可以解决这个问题吗?

最佳答案

试试这个简化的测试。如果这有效,请检查您的 result 是否真的包含您的想法(提醒它或将其写入控制台)。拆分后可能还有其他字符(即空格(前导空格,\t\r)尝试 trim 结果数组的每个值。

var data1 = ["a123", "b123", "c123", "d123", "e123", "f123", "g123", "h123", "i123", "j123",   "k123", "l123", "m123", "n123", "o123", "p123", "q123", "r123", "s123", "t123", "u123", "v123", "w123", "x123", "y123", "z123"];
var data2 = 'a123\nb123\nc123\nd123\ne123\nf123\ng123\nh123\ni123\nj123\nk123\nl123\nm123\nn123\no123\np123\nq123\nr123\ns123\nt123\nu123\nv123\nw123\nx123\ny123\nz123';
$("#inputfield1").autocomplete(data1);

$("#inputfield1").blur(function(){
    if($("#inputfield1").val() != ""){
        var result=data2.split("\n");
        $("#inputfield2").autocomplete(result);
    }
});

关于javascript - 如何将 jQuery 自动完成插件用于链接的输入字段?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/1838247/

相关文章:

javascript - 使用 jquery 从一列拖放到另一列

python - Ajax POST 在 Flask 中返回 render_template?

python - Django Ajax "FORBIDDEN"错误

javascript - meteor 数二的收藏值(value)

javascript - 在 Javascript 循环中分配变量

javascript - 提取 JSON 数据时如何将\n 转换为 <br> 标记?

jquery - 在 iOS 上的 Safari 和 Chrome 中只允许数字和冒号

javascript - React - 导入非模块化 sass 文件返回空对象

javascript - MouseMove 事件每秒重复一次

jquery - 过滤 JQuery Datatables 后检索行数据