我在一个页面上有多个自动完成功能。
当我对所有文本字段使用jQuery UI AutoComplete时,它将添加以下形式的动态选择列表
<ul id="ui-id-1" tabindex="0" class="ui-menu ui-widget ui-widget-content ui-autocomplete ui-front" style="top: 103px; left: 1678px; width: 256.828px; display: none;">
<li class="ui-menu-item"><div id="ui-id-234" tabindex="-1" class="ui-menu-item-wrapper">Entry 1</div></li>
</ul>
有一种CSS样式ui-autocomplete
,我需要针对每个字段进行不同的调整。但是,如何根据它们描述的DOM元素来定位个体 ui-autocomplete
选择框?
为什么要轻松地将属性(例如"domElement=myID"
添加到生成的任何选择列表框)为何如此困难?
我可以依靠的前后没有位置。选择列表添加在DOM的底部。
其中一个自动完成示例:
$('#addModalUserSearch').autocomplete({
source: function( request, response ) {
$.ajax({
url: "getAdminAddUserChoices",
dataType: "json",
type: "get",
data: {
'term': request.term,
'org': $('#adminUserOrg').val()
},
success: function( data ) {
response ($.map (data, function (item) {
return {
label: item.value,
value: item.key
}
}));
}
});
},
minLength: 2,
delay: 100,
select: function(event, ui) { ..}
我需要做类似的事情
.ui-autocomplete-1 {
top: 120px !important;
left: 80% !important;
}
.ui-autocomplete-2 {
top: 5%;
left: 60%;
}
答案 0 :(得分:1)
涉及自动完成功能时,有两种方法可以注入您自己的CSS。您的帖子并没有真正显示您想要的内容,所以我会尽量保持含糊。
请考虑以下内容:
$(function() {
$('#addModalUserSearch').autocomplete({
classes: {
"ui-autocomplete": "user-search"
},
source: function(request, response) {
$.ajax({
url: "getAdminAddUserChoices",
dataType: "json",
type: "get",
data: {
'term': request.term,
'org': $('#adminUserOrg').val()
},
success: function(data) {
response($.map(data, function(item) {
return {
label: item.value,
value: item.key
}
}));
}
});
},
minLength: 2,
delay: 100,
select: function(event, ui) {
//...
}
});
});
.user-search {
top: 120px !important;
left: 80% !important;
}
<link rel="stylesheet" href="//code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>
<div class="ui-widget">
<label for="addModalUserSearch">User: </label>
<input id="addModalUserSearch">
</div>
由于远程源,该示例基本上无法正常工作,但是您仍然可以看到基本列表的生成:
<ul id="ui-id-1" tabindex="0" class="ui-menu ui-widget ui-widget-content ui-autocomplete user-search ui-front" style="display: none;"></ul>
您可以看到类user-search
已列出,并且可以由CSS专门为此AutoComplete调用和设置样式。
您还可以考虑使用position
选项。
位置类型:对象,默认值:
{ my: "left top", at: "left bottom", collision: "none" }
标识建议菜单相对于关联的输入元素的位置。 of选项的默认值是输入元素,但是您可以指定要定位的另一个元素。您可以参考jQuery UI Position utility了解有关各种选项的更多详细信息。
执行此操作的另一种更为复杂的方法是利用_RenderMenu
扩展点。由于AutoComplete使用菜单来构建选择列表,因此您可以将其绑定以更深入地管理外观。
_renderMenu(ul,items),返回:jQuery(仅插件)
控制构建窗口小部件菜单的方法。该方法将传递一个空的
<ul>
和一个与用户键入的术语匹配的项目数组。各个<li>
元素的创建应委托给_renderItemData()
,后者又委托给_renderItem()
扩展点。
希望这会有所帮助。