jQuery UI自动完成自定义显示,如何关注子级而不是一级子级
jQuery UI Autocomplete custom display, how to focus sub children instead of first level children?
我正在尝试为jQuery UI Autocomplete使用一个自定义模板,其中可选择的子元素不仅仅是第一级<li>
子元素,它们将5个元素嵌套得更深。
如何通过箭头键和鼠标交互仅使某些元素、.search-result-single-item.ui-menu-item
可聚焦/可选择?
无论我尝试什么,它似乎只关注/选择ul.ui-autocomplete
中的第一级儿童
以下是我的内部自动完成结果的样本模板:
<ul class="ui-autocomplete ui-front ui-menu ui-widget ui-widget-content" id="ui-id-1" tabindex="0">
<div class="search-mini-container">
<div class="connecting-triangle">
<div class="connecting-triangle-border"></div>
</div>
<table class="search-category">
<tr>
<td class="search-category-icon-container">
<i class="fa fa-fw fa-lg fa-star text-custom-success"></i>
</td>
<td class="search-category-content">
<div class="title-view-all-container">
<div class="search-category-title text-custom-success">
Search Category Name
</div>
</div>
<div class="search-result-items">
<div class="search-result-single-item ui-menu-item">
Search Result #1
</div>
<div class="search-result-single-item ui-menu-item">
Search Result #2
</div>
</div>
</td>
</tr>
</table>
</div>
</ul>
如果我正确理解你的问题,你想从不同的类别自动完成。以下是JQuery UI自动完成的类别示例:
$(function() {
$.widget("custom.catcomplete", $.ui.autocomplete, {
_create: function() {
this._super();
this.widget().menu("option", "items", "> :not(.ui-autocomplete-category)");
},
_renderMenu: function(ul, items) {
var that = this,
currentCategory = "";
$.each(items, function(index, item) {
var li;
if (item.category != currentCategory) {
ul.append("<li class='ui-autocomplete-category'>" + item.category + "</li>");
currentCategory = item.category;
}
li = that._renderItemData(ul, item);
if (item.category) {
li.attr("aria-label", item.category + " : " + item.label);
}
});
}
});
var data = [{
label: "Groovy",
category: "C-like"
}, {
label: "Java",
category: "C-like"
}, {
label: "Perl",
category: "C-like"
}, {
label: "Clojure",
category: "Lisp"
}, {
label: "Scheme",
category: "Lisp"
}, {
label: "Lisp",
category: "Lisp"
}, {
label: "ActionScript",
category: "Scripting"
}, {
label: "AppleScript",
category: "Scripting"
}, {
label: "JavaScript",
category: "Scripting"
}, ];
$("#search").catcomplete({
delay: 0,
source: data
});
});
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.10.1/jquery.min.js"></script>
<script src="https://code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<link href="https://code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css" rel="stylesheet"></link>
<label for="search">Search:</label>
<input id="search">
相关文章:
- jQuery Facebox插件:关注弹出的外观
- “createImageData()”和“new ImageData(()”有何不同
- 使用BeautifulSoup从Javascript中提取文本以获得关注者数量
- 关注函数运行过的表单字段(新手)
- Jquery UI日期选择器不关注输入
- JQuery关注上一个点击的输入错误
- 当阻止Enter键提交AJAX表单时,关注下一个输入是't工作
- webpack只关注条目
- 关注键盘选项卡
- 如何检查用户是否开始关注
- 关于对增强网格中的行的关注
- jQuery将输入集中在下一个tr->td时,td包含一个输入字段,但从不关注html选择
- 如何检查用户是否已经在NodeJs-Mongoose中关注其他用户
- 自动完成:只有当用户键入制表键时,才关注第一个项目
- 如何使用nodejs步行模块将目录遍历到第一级
- 您如何控制在填写表单时单击下一步时 iOS/Android 将关注哪个字段
- 这与 $(document).ready() 有何不同
- 安装后以程序方式关注形状元素
- AngularJS不断关注文本输入
- jQuery UI自动完成自定义显示,如何关注子级而不是一级子级