我創建了一個InputFilter。這是我的代碼。如何在輸入標籤中選擇列表項目
MyFilter = function(args) {
var dataUrl = args.url;
var divID = args.divID;
var div = document.getElementById(divID);
//var input = '<input type="text" id="myInput" onclick="myFunction()" title="Type in a name">';
var myTable = '<input type="text" id="myInput" onkeyup="myFunction()" placeholder="Search for names.." title="Type in a name">' +
'<ul id="myUL">' + '<li>' + '<a href="#"></a>' + '</li>' + '</ul>';
div.innerHTML = myTable;
function foo(callback) {
var httpRequest = new XMLHttpRequest();
httpRequest.open('GET', "data.json", true);
httpRequest.onreadystatechange = function() {
if (httpRequest.readyState === XMLHttpRequest.DONE && httpRequest.status === 200) {
callback(httpRequest.responseText);
}
};
httpRequest.send();
}
foo(function(data) {
debugger;
var jsonc = JSON.parse(data);
var new_opt = "";
for (i = 0; i < jsonc.length; i++) {
new_opt += '<li><a href="#">' + jsonc[i]['VALUE'] + '</a></li>';
}
document.getElementById('myUL').innerHTML = new_opt;
});
myFunction = function() {
debugger;
var input, filter, ul, li, a, i;
input = document.getElementById("myInput");
filter = input.value.toUpperCase();
ul = document.getElementById("myUL");
li = ul.getElementsByTagName("li");
for (i = 0; i < li.length; i++) {
a = li[i].getElementsByTagName("a")[0];
if (a.innerHTML.toUpperCase().indexOf(filter) > -1) {
li[i].style.display = "";
} else {
li[i].style.display = "none";
}
}
}
}
我想要當我點擊列表項目,這些項目geteselected並顯示到輸入字段,像組合框。
任何人都可以請幫助我如何做到這一點。
這是我的小提琴手。 JS FIDDLE
注意:目前我的代碼能夠搜索,我想選擇並顯示在輸入中。
這是發生在其他項目,但我在這裏使用表。
代碼是
document.querySelectorAll('#myTable tr:not(.header)').forEach(function(_tr) {
_tr.addEventListener('click', function() {
document.getElementById('myInput').value += " ; " + this.getElementsByTagName('td')[0].textContent;
});
});
我想點擊a
標籤的項目,所選項目要通過;
分離,輸入標籤顯示。
定義'Inputfield' ... – vsync
@vsync我的意思是它是輸入標籤,我可以給一些輸入。 – David
標題很不清楚。你如果發佈了一個關於你想在UX上發生的事情的例子,它會幫助我改變@ – vsync