面板内的JQuery Mobile listview

时间:2015-06-17 12:20:29

标签: jquery-mobile jquery-mobile-listview jquery-mobile-collapsible jquery-mobile-panel

我正在尝试将listviews与面板中的可折叠项目一起使用,但我得到了奇怪的结果。具体来说,这是我正在使用的最小代码。请注意,列表视图中的所有内容都取自JQuery Mobile示例,因此我希望它能够开箱即用。

<!DOCTYPE HTML PUBLIC "-//IETF//DTD HTML//EN">
<html>
<head>
<title>Test</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="jquery.mobile-1.4.5.min.css" />
<script src="jquery-1.11.3.min.js"></script>
<script src="jquery.mobile-1.4.5.min.js"></script>
</head>

<body>
<h1></h1>

<div data-role="page" id="mainpage">

<div data-role="panel" id="leftpanel" data-position="left" data-display="push">
  <!-- panel content goes here -->
  <div data-role="tabs" id="tabs">
  <div data-role="navbar">
    <ul>
      <li><a href="#one-tab" data-ajax="false">one</a></li>
      <li><a href="#two-tab" data-ajax="false">two</a></li>
    </ul>
  </div>
  <div id="one-tab" class="ui-body-d ui-content">
    Empty one!
  </div>
  <div id="two-tab" class="ui-body-d ui-content">
    <ul data-role="listview" data-inset="true" data-shadow="false">
      <li data-role="collapsible" data-iconpos="right" data-inset="false">
      <h2>Birds</h2>
      <ul data-role="listview" data-theme="b">
        <li><a href=“#">Condor</a></li>
        <li><a href="#">Eagle</a></li>
        <li><a href="#">Sparrow</a></li>
      </ul>
      </li>
      <li><a href="#">Humans</a></li>
      <li data-role="collapsible" data-iconpos="right" data-inset="false">
      <h2>Fish</h2>
      <ul data-role="listview" data-theme="b">
        <li><a href="#">Salmon</a></li>
        <li><a href="#">Pollock</a></li>
        <li><a href="#">Trout</a></li>
      </ul>
      </li>
    </ul>
  </div>
  </div>
  </div>

  <div id="mainheader" data-role="header" data-position="fixed">
    <a href="#leftpanel" data-role="button" data-iconpos="notext" data-icon="bars"></a>
    <h1>Main page</h1>
  </div>

  Main page
  </div>  
  </body>
</html>

我得到的是类似的东西 enter image description here

哪个可能并不完全正常。我做错了什么?

1 个答案:

答案 0 :(得分:2)

您正在以jQM未设计处理的方式混合listviews和collapsibles。但是,你可以使这个看起来正确&#39;用一些CSS。

<ul id="tabTwoList" data-role="listview" data-inset="true" data-shadow="false">
    <li>
        <div data-role="collapsible" data-inset="false" data-iconpos="right">
            <h2>Birds</h2>
            <ul data-role="listview" data-theme="b">
                <li><a href="#">Condor</a></li>
                <li><a href="#">Eagle</a></li>
                <li><a href="#">Sparrow</a></li>
            </ul>
        </div>
    </li>
    <li><a href="#">Humans</a></li>
    <li>
        <div data-role="collapsible" data-inset="false" data-iconpos="right">
            <h2>Fish</h2>
            <ul data-role="listview" data-theme="b">
                <li><a href="#">Salmon</a></li>
                <li><a href="#">Pollock</a></li>
                <li><a href="#">Trout</a></li>
            </ul>
        </div>
    </li>
</ul>

在标记中,我已经为列表提供了一个ID,因此我们可以在CSS中轻松引用它,并且我已经在LI中创建了可折叠的DIV。现在我们使用CSS删除一些填充/边距/边框,以使所有项目排列良好:

#tabTwoList li.ui-li-static {
    padding-top: 0;
    padding-bottom: 0;
}
#tabTwoList li .ui-collapsible-heading {
    margin-top: 0;
    margin-bottom: 0;
}
#tabTwoList li .ui-collapsible-heading-toggle {
    border: 0;
}
  

正在使用 DEMO