是否有HTML5 DataList的SelectedIndex?

Cai*_*aio 10 javascript html5 html-datalist

您可以选择option任何select元素的当前值:

mySelect.options[mySelect.selectedIndex]
Run Code Online (Sandbox Code Playgroud)

我可以用DataList做同样的事吗?像这样的东西:

<input id = "input" list = "datalist" type = "text" />

<datalist id = "datalist">
    <option value = "No. 1"></option>
    <option value = "No. 2"></option>
    <option value = "No. 3"></option>
</datalist>

<script>
    var datalist = document.getElementById ("datalist");
    var input = document.getElementById ("input");

    input.addEventListener ("keyup", function (event) {
        if (event.which === 13) {
            alert (datalist.options[datalist.selectedIndex]); // Example
        }
    }, false);
</script>
Run Code Online (Sandbox Code Playgroud)

Dav*_*ang 9

不,datalist元素用于为输入提供自动完成功能.它是一个数据源,对用户是隐藏的,多个输入可以链接到它.因此,拥有一个没有意义selectedIndex.

相反,您应该只检查.value输入:

var datalist = document.getElementById ("datalist");
var input = document.getElementById ("input");

input.addEventListener ("keyup", function (event) {
    if (event.which === 13) {
        alert(input.value);
    }
}, false);
Run Code Online (Sandbox Code Playgroud)

  • 注意:当用户点击datalist(鼠标点击)中的下拉项时,不会触发任何事件(chrome21) (7认同)
  • 应该将事件监听器更改为"输入",因为它可以解决Dmitry提出的问题. (3认同)