Jquery UI自动完成。如何使用innerHTML在div中写入结果?

时间:2012-10-22 19:46:37

标签: jquery-ui html autocomplete innerhtml

我的网站上有一个自动填充字段。我只是想在-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>

Example

2 个答案:

答案 0 :(得分:10)

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

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

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

您可以在this update to your fiddle中看到结果。

答案 1 :(得分:4)

使用自动填充的公开活动,例如 jsFiddle example

    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);
    }