javascript - 如何在 jQuery Mobile 中将导航栏用作选项卡

标签 javascript jquery-mobile navbar

这是我在 fiddle 上试过的以下代码 Jsfiddle code

<div data-role="navbar">
<ul>
    <li><a href="#tab-1">Tab1</a></li>
    <li><a href="#tab-2">Tab2</a></li>
    <li><a href="#tab-3">Tab3</a></li>
</ul>
</div>

<div data-role="content">
    <div id="tab-1">
       <h2>Here is the first tab</h2>
    </div>

    <div id="tab-2">
        <h2>Here is the second tab</h2>
    </div>
    <div id="tab-3">
        <h2>Here is the third tab</h2>
    </div>
</div>
  1. 我需要默认显示第一个选项卡及其内容
  2. 我需要在显示一个特定选项卡时隐藏其他选项卡的内容

怎么做?

最佳答案

这是使用导航栏作为选项卡的示例代码。

<!DOCTYPE html> 
<html> 
    <head> 
    <title>My Page</title> 
    <meta name="viewport" content="width=device-width, initial-scale=1"> 
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.css" />
    <script src="http://code.jquery.com/jquery-1.6.4.min.js"></script>
    <script>
        var prevSelection = "tab1";
        $("#navbar ul li").live("click",function(){
            var newSelection = $(this).children("a").attr("data-tab-class");
            $("."+prevSelection).addClass("ui-screen-hidden");
            $("."+newSelection).removeClass("ui-screen-hidden");
            prevSelection = newSelection;
        });
    </script>
    <script src="http://code.jquery.com/mobile/1.0.1/jquery.mobile-1.0.1.min.js"></script>
    <style>
        .tab-content{
            width:100%;
            height:250px;
            background-color:white;
            border-bottom-left-radius:0.5em;
            border-bottom-right-radius:0.5em;
        }
        .tab-content>div{
            padding:5px;
        }                   

    </style>
    </head> 

    <body> 
        <div data-role="page">

        <div data-role="header">
        <h1>My Title</h1>
        </div><!-- /header -->

        <div data-role="content">   
            <div data-role="navbar" id="navbar">
                <ul>
                    <li><a href="#" class="ui-btn-active" data-tab-class="tab1">Tab1</a></li>
                    <li><a href="#" data-tab-class="tab2">Tab2</a></li>
                    <li><a href="#" data-tab-class="tab3">Tab3</a></li>
                    <li><a href="#" data-tab-class="tab4">Tab4</a></li>
                </ul>
            </div>
            <div class="tab-content">
                <div class="tab1">
                    Tab1
                </div>
                <div class="tab2 ui-screen-hidden">
                    Tab2
                </div>
                <div class="tab3 ui-screen-hidden">
                    Tab3
                </div>
                <div class="tab4 ui-screen-hidden">
                    Tab4
                </div>
            </div>
        </div><!-- /content -->

        </div><!-- /page -->
    </body>
</html>

演示 - http://jsfiddle.net/m8wQM/

如果有帮助,请告诉我。

关于javascript - 如何在 jQuery Mobile 中将导航栏用作选项卡,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9413734/

相关文章:

javascript - 返回列表 JS 中值的串联

javascript - Quora 在 Jquery Mobile 中样式化了 "add content"图标

javascript - Android - Jquery Mobile - 按钮通过警报框显示

jquery-mobile - 如何删除 jQuery Mobile RC2 中 URL 中的历史记录?

css - 菜单环绕和空白 :nowrap making the menu go past the page Wordpress

javascript - jquery fadein后如何滚动到div?

javascript - 在 Angular/ ionic 应用程序中捕获任意位置的点击/按下按钮/输入焦点

javascript - jquery 删除 BR 标签

html - 如何在我的导航栏中将 'nav' 元素移动到 'navbar-brand' 下

twitter-bootstrap - Bootstrap 下拉菜单点击后显示蓝框