Как создать панель вкладок в Bootstrap
Какой класс мне нужно использовать для панели вкладок? Есть один?
Я делаю следующее и плохо смотрю:-(
Вкладка с плавающей запятой + панель с пробелами и 0 между ними -
<div id="dashboardheader" class="container" style="padding-top: 20px;">
<ul class="nav nav-tabs tab-pane">
<li class="active"><a href="#">Dashboard</a></li>
</ul>
</div>
<div id="dashboardpanel " style="padding-top: 0px">
<div class="panel panel-primary container" style="padding-top: 30px;">
<div class="row">
<div class="col-md-offset-2 col-md-8 col-md-offset-2">
<div class="row">
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" onclick="OpenDialog()" />
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
</div>
</div>
</div>
<div class="row">
<div class="col-md-offset-2 col-md-8 col-md-offset-2">
<div class="row">
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
<img src="..\..\Content/Images/Dashboard/fgh.png" class="btn btn-lg" role="button" />
</div>
</div>
</div>
</div>
</div>
что есть альтернативный?
Ответы
Ответ 1
Я думаю, что вы хотите просто обычные вкладки начальной загрузки
<!-- Nav tabs -->
<ul class="nav nav-tabs" role="tablist">
<li class="active"><a href="#home" role="tab" data-toggle="tab">Home</a></li>
<li><a href="#profile" role="tab" data-toggle="tab">Profile</a></li>
<li><a href="#messages" role="tab" data-toggle="tab">Messages</a></li>
<li><a href="#settings" role="tab" data-toggle="tab">Settings</a></li>
</ul>
<!-- Tab panes -->
<div class="tab-content">
<div class="tab-pane active" id="home">...</div>
<div class="tab-pane" id="profile">...</div>
<div class="tab-pane" id="messages">...</div>
<div class="tab-pane" id="settings">...</div>
</div>
С небольшим количеством стилей вы можете посмотреть, как вы хотите:
![screenshot]()
Ответ 2
Вот несколько простых, которые вы можете добавить, что позволяет включать .nav.nav-tabs
внутри .panel .panel-heading
Пример codepen: http://codepen.io/anon/pen/utGaK
IMHO это не совсем выглядит "чистым", поскольку компоненты используются независимо от дополнительных стилей.
Я тестировал его с помощью .panel-title
, используя .pull-right
в .nav
. В то время как это сработало, я нашел, что лучше добавить .clearfix
в заголовок, поскольку вкладки - это 1/2px слишком высокий ATM. Должно быть просто решить его.
Вот код, который я использую в приведенном выше примере.
Например:
<div class="panel panel-default">
<div class="panel-heading">
<!-- Nav tabs -->
<ul class="nav nav-tabs" role="tablist">
<li class="active"><a href="#home" role="tab" data-toggle="tab">Home</a></li>
<li><a href="#profile" role="tab" data-toggle="tab">Profile</a></li>
<li><a href="#messages" role="tab" data-toggle="tab">Messages</a></li>
<li><a href="#settings" role="tab" data-toggle="tab">Settings</a></li>
</ul>
</div>
<!-- Tab panes + Panel body -->
<div class="panel-body tab-content">
<div class="tab-pane active" id="home">HOME</div>
<div class="tab-pane" id="profile">PROFILE</div>
<div class="tab-pane" id="messages">MESSAGES</div>
<div class="tab-pane" id="settings">SET</div>
</div>
</div>
Это тем меньше:
// Need to compensatve for padding in panel-heading
// Must be a way to invert this
// variable - @panel-heading-padding.
@panel-heading-padding-negate: -10px -15px;
.panel {
.panel-heading {
.nav-tabs {
margin:@panel-heading-padding-negate;
border-bottom-width:0;
> li {
> a {
// re-apply the original padding
padding:@panel-heading-padding;
margin-bottom:1px;
border:solid 0 transparent;
&:hover {
border-color: transparent;
}
}
&.active > a {
&,
&:hover,
&:focused {
border:solid 0 transparent;
}
}
}
}
}
}
UPDATE
Я добавил следующее в определение li
и удалил margin-right
и border-radius
в > li > a
, чтобы при наведении навигатора вправо от заголовка он подходит и выглядит более чистым.
&:first-child > a {
border-top-left-radius:@panel-border-radius;
}
&:last-child > a {
border-top-right-radius:@panel-border-radius;
}
Здесь обновлен код: http://codepen.io/anon/pen/hJsEC
Ответ 3
Вот фрагмент Bootsnipp, который делает это: http://bootsnipp.com/snippets/MaA0A
Он содержит CSS для включения вкладок в заголовок панели следующим образом:
<div class="panel with-nav-tabs panel-default">
<div class="panel-heading">
<ul class="nav nav-tabs">
<!--...-->
</ul>
</div>
<div class="panel-body">
<div class="tab-content">
<!--...-->
</div>
</div>
</div>
Результат:
![пример панели с вкладками]()
Ответ 4
Нашел простое решение для моделирования, основанное на структуре HTML Andrew:
.panel-heading>.nav-tabs {
border-bottom: none;
margin-bottom: -10px;
}
Ответ 5
<ul class="nav nav-tabs ">
<li class="active" > <a href="#One" data-target="#One" data-toggle="tab"> One </a> </li>
<li ><a href="#Two" data-target="#Two" data-toggle="tab"> Two </a> <li>
</ul>
<div class="tab-content clearfix">
<div class="tab-pane fade in active" id="One">
This is one
</div>
<div class="tab-pane fade " id="Two">
This is Two
</div>
</div>