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

yen*_*sen 3 html jquery-ui 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>
Run Code Online (Sandbox Code Playgroud)

.

例

Fré*_*idi 10

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

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

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

您可以在此更新中看到您的小提琴的结果.