错误的元素集中在Chrome

Wrong element focused in Chrome

本文关键字:Chrome 集中 元素 错误      更新时间:2023-09-26

在我的javascript web应用程序中,我有一个带有自定义单元格的表,具有读取模式(简单标签)和双击(输入)的编辑模式。当我处于编辑模式时,焦点设置在包含输入(在td中)的div上,然后我可以使用TAB移动到另一个单元格。当我处于读取模式时,焦点被设置在包含标签的div上,我可以使用TAB和箭头移动到另一个单元格。这在资源管理器中工作完美,但在Chrome中,在读取模式下,重点是不同的:是设置在表元素上,然后我不能使用TAB和箭头移动到另一个单元格。我也试过强制对焦设置间隔:

$("#iddiv").focus()

问题只是在Chrome上

<table>
<tbody>
<tr>
<td>
<div class='...'>
<label></label>
</div>
</td>
......
</tr>
</tbody>
</table>

<div> s上设置tabindex="0"的属性(在本博客文章中找到的技术)

$(function() {
  $('div[tabindex]').first().focus();
});
td {
  outline: 1px solid grey;
}
td label {
  display: inline-block;
  padding: 5px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<table>
  <tbody>
    <tr>
      <td>
        <div tabindex="0">
          <label>Cell 1</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 2</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 3</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 4</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 5</label>
        </div>
      </td>
    </tr>
    <tr>
      <td>
        <div tabindex="0">
          <label>Cell 6</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 7</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 8</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 9</label>
        </div>
      </td>
      <td>
        <div tabindex="0">
          <label>Cell 10</label>
        </div>
      </td>
    </tr>
  </tbody>
</table>