Dar*_*awg 8 javascript jquery jquery-ui jquery-ui-autocomplete
我正在使用jQuery 1.11.2并尝试获取自动完成小部件来解析数据数组.我有阵中的人,Will Smith和Willem Dafoe.当我在文本字段中输入Wi时,我希望看到两个名称都被添加到下拉列表中,但我没有得到任何响应.这是代码的副本:
<script src="js/jquery/jquery-1.11.2.js"></script>
<script src="js/jquery/jquery-ui.js"></script>
<link rel="stylesheet" href="js/jquery/jquery-ui.css"/>
<link rel="stylesheet" href="js/jquery/jquery-ui.theme.css"/>
<script type="text/javascript">
$(function() {
var data = [
{
"id": 1,
"first_name": "Will",
"last_name": "Smith",
"created_at": "2015-01-27T13:09:20.243Z",
"updated_at": "2015-01-27T13:09:20.243Z"
},
{
"id": 2,
"first_name": "Willem",
"last_name": "Dafoe",
"created_at": "2015-01-27T13:17:23.479Z",
"updated_at": "2015-01-27T13:17:23.479Z"
}
];
// Below is the name of the textfield that will be autocomplete
$('#search').autocomplete({
// This shows the min length of charcters that must be typed before the autocomplete looks for a match.
minLength: 2,
// This is the source of the auocomplete suggestions. In this case a list of names from the people controller, in JSON format.
source:data,
// This updates the textfield when you move the updown the suggestions list, with your keyboard. In our case it will reflect the same value that you see in the suggestions which is the person.given_name.
focus: function(event, ui) {
$('#search').val(ui.item.first_name);
return false;
},
// Once a value in the drop down list is selected, do the following:
select: function(event, ui) {
// place the person.given_name value into the textfield called 'select_origin'...
$('#search').val(ui.item.first_name);
// and place the person.id into the hidden textfield called 'link_origin_id'.
$('#link_origin_id').val(ui.item.id);
return false;
}
}).data( "ui-autocomplete" )._renderItem = function( ul, item ) {
return $( "<li></li>" ).data( "ui-autocomplete-item", item ).append( "<a>" + item.first_name + "</a>" ).appendTo( ul );
// For now which just want to show the person.given_name in the list.
};
});
</script>
Search: <input type="text" id="search" />
Run Code Online (Sandbox Code Playgroud)
代码全部位于本地驱动器上的单个html文件夹中.此时不涉及服务器.此外,我已检查inspect元素工具是否有错误,但未显示任何错误,并且找到并加载了所有资源.
Run*_*orn 24
问题是Autocomplete无法呈现其功能的来源.
您需要根据使用的JSON数据设置自动完成的来源,
source: function (request, response) {
//data :: JSON list defined
response($.map(data, function (value, key) {
return {
label: value.first_name,
value: value.id
}
}));
},
Run Code Online (Sandbox Code Playgroud)
而且,我还.data从代码中删除了回调.
工作答案 - 正确过滤。接受的答案中的过滤不起作用,因为没有针对request.term.
var mydata =
[{"id": 1, "name": "John", "age": 23},
{"id": 2, "name": "Mary", "age": 33},
{"id": 3, "name": "Richard", "age": 53},
{"id": 4, "name": "Ashley", "age": 25},
{"id": 5, "name": "Kyle", "age": 17},
{"id": 6, "name": "Samantha", "age": 29},
{"id": 7, "name": "David", "age": 43},
{"id": 8, "name": "Charles", "age": 27},
{"id": 9, "name": "Elaine", "age": 41},
{"id": 10, "name": "William", "age": 22}
];
$('#myautocomplete').autocomplete({
minLength: 2,
source: function (request, response) {
response($.map(mydata, function (obj, key) {
var name = obj.name.toUpperCase();
if (name.indexOf(request.term.toUpperCase()) != -1) {
return {
label: obj.name + " (" + obj.age + ")", // Label for Display
value: obj.id // Value
}
} else {
return null;
}
}));
},
focus: function(event, ui) {
event.preventDefault();
},
// Once a value in the drop down list is selected, do the following:
select: function(event, ui) {
event.preventDefault();
// place the person.given_name value into the textfield called 'select_origin'...
$('#myautocomplete').val(ui.item.label);
// ... any other tasks (like setting Hidden Fields) go here...
}
});
Run Code Online (Sandbox Code Playgroud)
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.3.1/css/bootstrap.min.css" rel="stylesheet"/>
<script src="https://cdnjs.cloudflare.com/ajax/libs/twitter-bootstrap/4.3.1/js/bootstrap.bundle.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
<link href="https://cdnjs.cloudflare.com/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css" rel="stylesheet"/>
e.g. Try the string "ar" for filtering<br/>
<input id="myautocomplete" type="text" placeholder="type some key string..." />Run Code Online (Sandbox Code Playgroud)