首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >是否有针对HTML5 DataList的SelectedIndex?

是否有针对HTML5 DataList的SelectedIndex?
EN

Stack Overflow用户
提问于 2011-01-18 21:39:24
回答 5查看 22.3K关注 0票数 11

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

代码语言:javascript
复制
mySelect.options[mySelect.selectedIndex]

我能用DataList做同样的事情吗?如下所示:

代码语言:javascript
复制
<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>
EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2011-01-18 21:50:24

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

相反,您只需检查输入的.value

代码语言:javascript
复制
var datalist = document.getElementById ("datalist");
var input = document.getElementById ("input");

input.addEventListener ("keyup", function (event) {
    if (event.which === 13) {
        alert(input.value);
    }
}, false);
票数 10
EN

Stack Overflow用户

发布于 2011-01-18 21:49:54

根据specs判断,datalist对象不具有selectedIndex属性。但是你可以找到它的默认选项,它有selected。或者将输入的值与每个选项值进行比较,然后手动查找索引。

票数 2
EN

Stack Overflow用户

发布于 2013-05-07 13:57:35

代码语言:javascript
复制
for (var i=0;i<datalist_id.options.length;i++)
    if (datalist_id.options[i].value == input_id.value) 
        {alert(datalist_id.options[i].innerText);break;}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/4724713

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档