2

我正在使用 jquery v 2.0.0 和 jquery ui 1.10.3

以下是我的 jquery ui 自动完成代码:

$nameField.combobox({
            source: people,
            buttonSelector: '.toggleList',
            focus: function () {
                return false;
            },
            select: function (event, ui) {
                $nameField.val(ui.item.name).data({
                    id: ui.item.id,
                    name: ui.item.name,
                    birthdate: ui.item.birthdate
                });
                return false;
            }
        }).data('ui-autocomplete')._renderItem = function (ul, item) {
            if (!_.include(self.idArr, item.id)) {
                return $('<li></li>').data('ui-autocomplete-item', item).append('<a>' + item.name + '</a>').appendTo(ul);
            }
        };

这在旧版本的 jquery 中运行良好。但是升级后,当我单击.toggleList按钮时,它会第一次打开,并且还有另一个按钮可以将所选名称添加到 div 中。之后,当我单击“.toggleList”组合选择器时,自动完成功能没有打开。它给了我以下错误:

Uncaught TypeError: Cannot call method 'data' of undefined jquery.ui.autocomplete.js?1376892069:527

有人遇到过这样的问题吗?我尝试了其他 stackoverflow 线程中提到的几个修复,但没有一个对我有用。

希望有人可以帮助我修复这个错误

谢谢

4

1 回答 1

2

我找到了解决方案!

有些人认为“ui-autocomplete”是错误的,所以他们使用“autocomplete”或“uiAutocomplete”,但这是错误的。实际上,“ui-autocomplete”是做到这一点的正确方法。

我有同样的问题,我和朋友一起发现了这段代码的问题。反而:

.data('ui-autocomplete')._renderItem = function (ul, item) {
            if (!_.include(self.idArr, item.id)) {
                return $('<li></li>').data('ui-autocomplete-item', item).append('<a>' + item.name + '</a>').appendTo(ul);
            }
        };

利用:

._renderItem = function (ul, item) {
            if (!_.include(self.idArr, item.id)) {
                return $('<li></li>').data('ui-autocomplete-item', item).append('<a>' + item.name + '</a>').appendTo(ul);
            }
        };

我认为组合框和自动完成返回一个数据('ui-autocomplete'),所以如果你输入 .data('ui-autocomplete') 你正在做类似的事情:

.data('ui-autocomplete').data('ui-autocomplete')

怎么了....好吧,实际上我不知道为什么这不起作用以及为什么没有它起作用,但是相信我,删除 .data('ui-autocomplete') 并感到高兴!

于 2013-09-17T13:39:11.997 回答