3

我的网站中有一个自动完成字段。我只想在 -div- 标记内显示结果,而不是插件本机打开的弹出窗口。

我已经在其他帖子中搜索过解决方案,但他们所做的是改变“弹出”窗口的位置,我想要的是用结果替换 -div- 的内容,而不是放置弹出窗口超过它。

任何建议将不胜感激。

这是我拥有的代码:

<!doctype html>

<html lang="en">
<head>
    <meta charset="utf-8" />
    <title>jQuery UI Autocomplete - Default functionality</title>
    <link rel="stylesheet" href="http://code.jquery.com/ui/1.9.0/themes/base/jquery-ui.css" />
    <script src="http://code.jquery.com/jquery-1.8.2.js"></script>
    <script src="http://code.jquery.com/ui/1.9.0/jquery-ui.js"></script>
    <link rel="stylesheet" href="/resources/demos/style.css" />
    <script>
    $(function() {
        var availableTags = [
            "ActionScript",
            "AppleScript",
            "Asp",
            "BASIC",
            "C",
            "C++",
            "Clojure",
            "COBOL",
            "ColdFusion",
            "Erlang",
            "Fortran",
            "Groovy",
            "Haskell",
            "Java",
            "JavaScript",
            "Lisp",
            "Perl",
            "PHP",
            "Python",
            "Ruby",
            "Scala",
            "Scheme"
        ];
        $( "#tags" ).autocomplete({
            source: availableTags
        });
    });
    </script>
</head>
<body>

<div class="ui-widget">
    <label for="tags">Tags: </label>
    <input id="tags" />
</div>


</body>
</html>

.

例子

4

2 回答 2

10

正如 j08691 所说,您必须处理小部件的打开事件。但是,由于您还想选择#results元素中的项目,因此复制它们是不够的。

我建议您#results改为在元素下重新设置整个自动完成菜单,并将其位置样式属性重置为static,使其保持原位:

$("#tags").autocomplete({
    source: availableTags,
    open: function() {
        $(this).autocomplete("widget")
               .appendTo("#results")
               .css("position", "static");
    }
});

您可以在fiddle 的此更新中看到结果。

于 2012-10-22T21:58:04.950 回答
4

在这个jsFiddle 示例中使用自动完成的打开事件。

    open: function(e, ui) {
        var list = '';
        var results = $('ul.ui-autocomplete.ui-widget-content a');
        results.each(function() {
            list += $(this).html() + '<br />';
        });
        $('#results').html(list);
    }
于 2012-10-22T20:04:26.810 回答