我有一个表格,里面有不同的字段。我使用下拉按钮代替常规的选择标签,以获得更好的用户体验。但是,问题在于,当我在其他文本输入字段上按Enter键时,此下拉列表始终会被聚焦。这很烦人并引起麻烦。

<form>
    <div class="row">
        <div class="col-md-6">
            <button type="button" class="btn btn-white dropdown-toggle" data-toggle="dropdown">
            <span class="dropdown-label">
                Test
            </span>
          </button>
          <button data-toggle="dropdown" class="btn btn-small btn-white dropdown-toggle">
            <span class="caret"></span>
          </button>
          <ul class="dropdown-menu dropdown-select" role="menu">
              <li><a>
                Testing 1
              </a></li>
              <li><a>
                Testing 2
              </a></li>
          </ul>
        </div>
        <div class="col-md-6">
            <input type="text" class="form-control"/>
        </div>
    </div>
</form>

这是JS fiddle :http://jsfiddle.net/ergLb/

你们知道为什么吗?

最佳答案

默认情况下,当在文本框中按下enter键时,它似乎会以某种方式出现,它将触发下拉菜单中的click事件。您可以使用e.preventDefault()return false来防止这种默认行为:

$(".form-control").keydown(function(e){
    if(e.keyCode == 13) {
        return false;
    }
});

Updated Fiddle

10-06 04:34