0

这段代码有什么问题?为什么这个 JSfiddle 不起作用?

HTML

<input id="university" name="university" type="text" />

Javascript

 $(function () {

        var jsonsample = [{
            "name": "Stanford University"
        }, {
            "name": "Santa Clara University"
        }]

        $('#university').autocomplete({

            minLength: 2,

            source: 'jsonsample',

            focus: function (event, ui) {
                $('#university').val(ui.item.name);
                return false;
            },

            select: function (event, ui) {

                $('#university').val(ui.item.name);

                return false;
            }
        })


            .data("autocomplete")._renderItem = function (ul, item) {
            return $("<li></li>")
                .data("item.autocomplete", item)

                .append("<a>" + item.name + "</a>")
                .appendTo(ul);
        };

    });

jsfiddle.net/venomoustoad/9yBcZ

为什么我会收到“请使用 POST 请求”?

理想情况下,我正在寻找自动完成来填充 jsonsample 对象中的名称。

4

1 回答 1

1

你有源作为一个字符串,它不应该有引号

source: 'jsonsample',

删除它们

source: jsonsample,

你似乎打错了演示

.data( "autocomplete" )._renderItem = function( ul

它应该是

.data( "ui-autocomplete" )._renderItem = function( ul

你需要在你的数组中有一个值

    [{
        "value": "Stanford University"
        "name": "Stanford University"
    }, {

JSFiddle:http: //jsfiddle.net/NsBGH/

于 2013-09-11T04:29:02.990 回答