jQuery自动完成和焦点事件

时间:2011-06-05 13:04:49

标签: jquery-ui autocomplete focus

Mornin'all,

我在使用jQuery UI自动完成小部件事件时遇到了麻烦。 我想将自定义类添加到所选项的父<li>。 生成的标记如下所示:

<li class="result">
   <a><span></span></a>
</li>

当项目是焦点时,jQuery将类.ui-state-hover添加到<a> 如何向家长.selected添加课程<li>? 我正在尝试从focus事件中执行此操作,但我不知道如何访问父<li>。 我查看了jQuery UI的来源,找到了应用.ui-state-hover的位置和方式,但没有帮助。

以下是我的自动填充代码。

/**
* Override the default behavior of autocomplete.data('autocomplete')._renderItem.
*
* @param ul _object_ The conventional ul container of the autocomplete list.
* @param item _object_ The conventional object used to represent autocomplete data.
* {value:'',label:'',desc:'',icon:''}
*/
var renderItemOverride = function (ul, item) {
        return $('<li class="result"></li>')
                .data("item.autocomplete", item)
                .append('<a><span class="name">' + item.label + '</span><span class="type"></span></a>')
                .appendTo(ul);
};

$('#live_search').autocomplete({
    source: function(request, response) {

        $.ajax({
            url: "search.json",
            dataType: "json",
            cache: false,
            data: {
                term: request.term
            },
            success: function(data ) {
                response($.map(data.contacts, function(item) {
                    return {
                        label: item.name || (iterm.firstname + item.lastname),
                        value: item.name || (iterm.firstname + item.lastname),
                        id:    item._id
                    }
                }));
            }
        });

    },
    appendTo: '.live_search_result_list',
    autoFocus: true,
    minLength: 2,
    focus: function(event, ui) {

    },
    select: function(event, ui) {
        console.log("do a redirection");
    }

}).data('autocomplete')._renderItem = renderItemOverride;

})

任何忍者都可以提供帮助吗?

1 个答案:

答案 0 :(得分:5)

怎么样:

focus: function(event, ui) {
    $(".live_search_result_list li.result").removeClass("selected");
    $("#ui-active-menuitem")
        .closest("li")
        .addClass("selected");
},

然后,当菜单失去鼠标时,要从任何selected中删除li类:

$(".live_search_result_list ul").mouseleave(function() {
    $(this).children("li.result").removeClass("selected");
});

以下是一个有效的例子:http://jsfiddle.net/andrewwhitaker/4z3SQ/