javascript - jQuery 自动完成数据未定义错误

标签 javascript jquery jquery-ui jquery-ui-autocomplete

我正在使用 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 线程中提到的几个修复,但没有一个对我有用。

希望有人能帮我修复这个错误

谢谢

最佳答案

我找到了解决方案!

有些人认为“ui-autocomplete”是错误的,因此他们使用“autocomplete”或“uiAutocomplete”,但这是错误的。实际上,“ui-autocomplete”是执行此操作的正确方法。

我和你有同样的问题,我和一个 friend 一起发现了这段代码的问题。相反:

.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') 并感到高兴!

关于javascript - jQuery 自动完成数据未定义错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18349929/

相关文章:

javascript - 在 TypeScript 中声明 javascript 文件的方法 :

Jquery UI - Chrome 无法在不破坏我的 CSS 的情况下产生效果

鼠标悬停时显示 JQuery UI 自动完成功能

javascript - 在 iPhone 上的 React Native 中访问相机时出现问题

java - 不情愿的量词在 Javascript 中不起作用

javascript - 使用 Nodejs 和 Express 进行异步调用

css - 如何让 Bootstrap Tour 使用 jQuery 对话框?

javascript - 如何在不复制的情况下重复刷新div?

jquery - jquery 使图像不可点击

javascript - 在 `Draggable` 之后追加 `Droppable`