如何修复 jQuery mobile 子菜单中的标题

Posted

技术标签:

【中文标题】如何修复 jQuery mobile 子菜单中的标题【英文标题】:How to fix header in submenu of jQuery mobile 【发布时间】:2020-06-05 07:32:08 【问题描述】:

我对 jQuery 很陌生,无法解决以下问题:我有一个主菜单,单击主菜单会打开一个包含多个项目的子菜单。

<head>
  <link rel="stylesheet" href="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.css">
  <script src="http://code.jquery.com/jquery-1.11.1.min.js"></script>
  <script src="http://code.jquery.com/mobile/1.4.5/jquery.mobile-1.4.5.min.js"> </script>
</head>
<div role="main" class="ui-content" style="background-color:#dae5f4;">
  <div class="ui-field-contain">
    <!-- ui-field-contain to wrap select elements -->
    <label for="items" class="select">Sub-Header</label> 
    <select id="items" name="items" size="1" data-native-menu="false">
      <option value="">Main-Header</option>
      <option value=1>Item 1</option>
      <option value=2>Item 2</option>
      <option value=3>Item 3</option>
      <option value=4>Item 4</option>
      <option value=5>Item 5</option>
      <option value=6>Item 6</option>
      <option value=7>Item 7</option>
      <option value=8>Item 8</option>
      <option value=9>Item 9</option>
      <option value=10>Item 10</option>
      <option value=11>Item 11</option>
      <option value=12>Item 12</option>
      <option value=13>Item 13</option>
      <option value=14>Item 14</option>
      <option value=15>Item 15</option>
      <option value=16>Item 16</option>
      <option value=17>Item 17</option>
      <option value=18>Item 18</option>
      <option value=19>Item 19</option>
      <option value=20>Item 20</option>
      <option value=21>Item 21</option>
      <option value=22>Item 22</option>
      <option value=23>Item 23</option>
      <option value=24>Item 24</option>
      <option value=25>Item 25</option>
      <option value=26>Item 26</option>
      <option value=27>Item 27</option>
      <option value=28>Item 28</option>
      <option value=29>Item 29</option>
      <option value=30>Item 30</option>
    </select>
  </div>
  <!-- end of div class=ui-field-contain -->
</div>
<!-- end of div role main -->

现在,我想修复子标题,使其不再随所有项目一起滚动。不幸的是,data-position="fixed" 不起作用。

【问题讨论】:

【参考方案1】:

您可以使用 CSS 解决它。 如果您想限制弹出窗口在打开时不滚动的高度,您可以使用 60vh 的 max-height 或类似设置垂直滚动。

.ui-selectmenu.ui-dialog .ui-content 
  max-height: 60vh;
  overflow-y: scroll;

如果你想修复它,添加这个 CSS:

#items-dialog 
  position: fixed;
  left: 0;
  top: 0;

【讨论】:

谢谢阿扎美津!是否有可能,在选择项目时通过 CSS 更改左上角 X 的颜色? 您可以使用 .ui-btn-icon-notext 类使用 CSS 选择它,但我建议您使用一个类来包装所有内容,以便在选择时更加具体。我不明白你所说的“当一个项目被选中时”是什么意思。

以上是关于如何修复 jQuery mobile 子菜单中的标题的主要内容,如果未能解决你的问题,请参考以下文章

如何修改jQuery mobile子菜单中的关闭按钮以进行初始打开

jQuery mobile 修复了 iPad 中的标题问题

如何修复 jQuery Mobile 的固定页脚?

JQuery mobile 中的多个可过滤选择菜单

如何在 jquery 3.1.0 中使用“滑动菜单 Jquery Mobile”?

jQuery Mobile 表单选择菜单