javascript – HTML5 DataList有SelectedIndex吗?

您可以选择任何select元素的当前选项:
mySelect.options[mySelect.selectedindex]

我可以用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>

解决方法

不,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);

相关文章

什么是深拷贝与浅拷贝?深拷贝与浅拷贝是js中处理对象或数据...
前言 今天复习了一些前端算法题,写到一两道比较有意思的题:...
最近在看回JavaScript的面试题,this 指向问题是入坑前端必须...
js如何实现弹出form提交表单?(图文+视频)
js怎么获取复选框选中的值
js如何实现倒计时跳转页面