如何在不使用下拉列表的情况下实施自动完成功能?

时间:2011-01-11 23:08:00

标签: javascript jquery autocomplete

如何在没有下拉列表的情况下实施自动填充功能?我希望自动填充功能以备用灰色填充文本框中的剩余字母,如图所示enter image description here

  

NB :我不是在寻找正常的JQuery UI Autocomplete plugin

1 个答案:

答案 0 :(得分:21)

  

jQuery.suggest.js

     

这里的讨论导致了jQuery插件的开发,   你可以在这里找到:http://polarblau.github.com/suggest/

     

以下所有代码和示例都已过时,但可能仍然存在   有些人感兴趣。


我一直对这个问题的结果非常感兴趣,但似乎还没有找到任何结果。

我已经考虑过编写自己的解决方案一段时间了,我可以告诉你我的想法(这只是在我脑海中,现在绝对没有尝试过):

HTML:

<div id="search-container">
    <input type="text" name="search" id="search" />
    <input type="text" disabled="disabled" id="suggestion" />
</div>

CSS:

#container {
    position: relative;
}

#search {
    position: relative;
    color: #000;
    z-index: 10;
    background: transparent;
    // border, etc....
}

#suggestion {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    color: #ccc;
    border: none;
    // ...
}

使用 Javascript 'onkeydown'来匹配第一个(排序标准在这里很重要)单词来自一个列表,该列表在单词的开头共享已输入的字母并将其放入禁用的输入中字段#suggestion。如果用户点击进入,则#suggestion中的字词将被转移到#search输入字段,并可能会提交表单。

如果我找到时间,我会尝试使其成为一个有效的jQuery插件 - 让我们看看。但也许你明白了吗?


修改

我已经尝试了我的想法,似乎work in it's simplest form很好。我很快就会在github account将它作为一个小jQuery插件发布。一旦我完成,我会在这里给你留言。或者继续给自己一个破解,让我知道它是如何发生的。

这是我最终使用的代码(部分代码可能是动态生成的):

<强> HTML:

<div id="search-container">
    <input type="text" name="search" id="search" />
    <input type="text" disabled="disabled" id="suggestion" />
</div>

<强> CSS:

* { margin: 0; padding: 0; }

#search-container {
    position: relative;
}

#search-container input {

    padding: 5px;
    font-size: 1.2em;
    width: 200px;
}

#search {
    position: relative;
    color: #000;
    z-index: 10;
    border: 1px solid #666;
    background: transparent;
}

#suggestion {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    color: #ccc;
    background: transparent;
    border: 1px solid #fff;
}

<强> JAVASCRIPT:

$(function() {

    var haystack = [
        "ActionScript",
        "AppleScript",
        "Asp",
        "BASIC",
        "C",
        "C++",
        "Clojure",
        "COBOL",
        "ColdFusion",
        "Erlang",
        "Fortran",
        "Groovy",
        "Haskell",
        "Java",
        "JavaScript",
        "Lisp",
        "Perl",
        "PHP",
        "Python",
        "Ruby",
        "Scala",
        "Scheme"
        ];

    $('#search').keyup(function(e) {
        // 'enter' key was pressed
        var $suggest = $('#suggestion');
        var code = (e.keyCode ? e.keyCode : e.which);
        if(code == 13) {
            $(this).val($suggest.val());
            $suggest.val("");
            return false;
        }

        // some other key was pressed
        var needle = $(this).val();

        // is the field empty?
        if (!$.trim(needle).length) {
            $suggest.val("");
            return false;
        }

        // compare input with haystack
        $.each(haystack, function(i, term) {
            var regex = new RegExp('^' + needle, 'i');
            if (regex.test(term)) {
                $suggest.val(needle + term.slice(needle.length));
                // use first result
                return false;
            }
            $suggest.val("");
        });
    });

});