Ste*_*ven 1 jquery jquery-ui-autocomplete
我目前.data( "ui-autocomplete" )._renderItem = function( ul, item )在我的页面中的三个地方使用.现在我需要再添加一个,我已经完成了.
但是这次我得到了错误信息
TypeError:this._renderItem(...)未定义
奇怪的是,如果我的IF测试是假的,我只会得到这个.
.data( "ui-autocomplete" )._renderItem = function( ul, item ) {
// If only one row is returned and ID = 0, then return 'no result' message
if(item.id == '0') {
return jQuery( "<li></li>" )
.data( "item.autocomplete", item )
.append( "<div class='no-result'>"+ item.value + "</div>" )
.appendTo( ul );
}
Run Code Online (Sandbox Code Playgroud)
我无法弄清楚为什么它在这里失败了,而不是在其他3个地方.某处有冲突吗?
这是我的代码
jQuery('#my-selector').autocomplete({
minLength: 2,
source: function( request, response ) {
jQuery.ajax({
url: callback_url,
dataType: "json",
data: {
term: request.term
},
success: function( data ) {
response( jQuery.map( data, function( item ) {
return {
id: item.id,
value: item.name,
name_encoded: item.name_encoded
}
}));
}
});
},
select: function( event, ui ) {
return false;
}
}).data( "ui-autocomplete" )._renderItem = function( ul, item ) {
if(item.id == '0') {
return jQuery( "<li></li>" )
.data( "item.autocomplete", item )
.append( "<div class='no-result'>"+ item.value + "</div>" )
.appendTo( ul );
}
};
Run Code Online (Sandbox Code Playgroud)
更新
这种改变有效.但我仍然不明白为什么我必须else在这里使用一个声明,当我不在其他两个autocomplete函数中使用它时.
.data( "ui-autocomplete" )._renderItemData = function( ul, item ) {
if(item.id == '0') {
return jQuery( "<li></li>" )
.data( "item.autocomplete", item )
.append( "<div class='no-result'>"+ item.value + "</div>" )
.appendTo( ul );
} else {
return this._renderItem( ul, item ).data( "ui-autocomplete-item", item );
}
};
Run Code Online (Sandbox Code Playgroud)
使用搜索词从查询中返回数据 some
[
{"id":"8186","name":"Some Are Thieves"},
{"id":"6149","name":"Somet"},
{"id":"6150","name":"Somethin'Else from SKECHERS"}
]
Run Code Online (Sandbox Code Playgroud)
正是由于测试,如果测试失败,则_renderItem不会返回任何等于返回的值undefined.
但是_renderItem,如下所示,由于jquery尝试将数据值设置为返回值,因此会导致错误.
return this._renderItem( ul, item ).data( "ui-autocomplete-item", item );
Run Code Online (Sandbox Code Playgroud)
在你的情况下,你必须覆盖_renderItemData而不是_renderItem
var el = $('<my-autocomplete-element>');
var _renderItemData = el.data("ui-autocomplete")._renderItemData;
el.data("ui-autocomplete")._renderItemData = function(ul, item) {
// If only one row is returned and ID = 0, then return 'no result' message
if (item.id == '0') {
return jQuery("<li></li>").data("item.autocomplete", item).data(
"ui-autocomplete-item", item).append("<div class='no-result'>"
+ item.value + "</div>").appendTo(ul);
} else {
_renderItemData.apply(this, arguments)
}
}
Run Code Online (Sandbox Code Playgroud)
演示:Plunker
| 归档时间: |
|
| 查看次数: |
9538 次 |
| 最近记录: |