带有垂直标签的ng-bootstrap?

时间:2018-04-16 21:26:35

标签: angular ng-bootstrap

我试图垂直使用ng-Bootstrap标签。他们给出了一个例子,但它不是我需要的,我希望它看起来像我在图中所拥有的。 这种配置是否可行?关于采取何种方向的任何想法?

enter image description here

1 个答案:

答案 0 :(得分:1)

以下是垂直标签的示例代码。

  

HTML

    <div class="row">
    <div class="col-md-12">  
      <h3 id="event-list-margin">Vartical Tabs</h3>
    </div>
<div class="col-md-12">
    <div class="col-xs-3"> <!-- required for floating -->
      <!-- Nav tabs -->
      <ul class="nav nav-tabs tabs-left">
        <li [ngClass]="{'active': tab.active}" *ngFor="let tab of tabs">
          <a (click)="tabChange(tab)">{{tab.name}}</a>
        </li>

      </ul>
    </div>

    <div class="col-xs-9">
      <div class="tab-content">
        <div class="tab-pane active" [ngClass]="{'showTab':selectedUserTab == 1, 'hideTab':selectedUserTab != 1}"> <!-- Profile tab -->
            <div class="panel panel-default">
                <div class="panel-heading">
                    Title one
                </div> 
                <div class="panel-body">

                </div>  
            </div>
        </div>

        <div class="tab-pane active" [ngClass]="{'showTab':selectedUserTab == 2, 'hideTab':selectedUserTab != 2}"> <!-- Change password tab -->
            <div class="panel panel-default">
                <div class="panel-heading">
                    Title Two
                </div> 
                <div class="panel-body">

                </div>  
            </div>
        </div>

        <div class="tab-pane active" [ngClass]="{'showTab':selectedUserTab == 3, 'hideTab':selectedUserTab != 3}"> <!-- Admin tab -->
            <div class="panel panel-default">
                <div class="panel-heading">
                    Title Three
                </div> 
                <div class="panel-body">

                </div>  
            </div>
        </div>

        <div class="tab-pane active" [ngClass]="{'showTab':selectedUserTab == 4, 'hideTab':selectedUserTab != 4}"> <!-- stripe account tab -->
          <div class="panel panel-default">
              <div class="panel-heading">
                Title Four
              </div> 
              <div class="panel-body">

              </div>    
          </div>
        </div>   
      </div>
    </div>
</div>
</div>
  

CSS

            .tabs-left, .tabs-right {
            border-bottom: none;
            padding-top: 2px;
        }
        .tabs-left {
            border-right: 1px solid #ddd;
        }
        .tabs-right {
            border-left: 1px solid #ddd;
        }
        .tabs-left>li, .tabs-right>li {
            float: none;
            margin-bottom: 2px;
        }
        .tabs-left>li {
            margin-right: -1px;
        }
        .tabs-right>li {
            margin-left: -1px;
        }
        .tabs-left>li.active>a,
        .tabs-left>li.active>a:hover,
        .tabs-left>li.active>a:focus {
            border-bottom-color: #ddd;
            border-right-color: transparent;
        }

        .tabs-right>li.active>a,
        .tabs-right>li.active>a:hover,
        .tabs-right>li.active>a:focus {
            border-bottom: 1px solid #ddd;
            border-left-color: transparent;
        }
        .tabs-left>li>a {
            border-radius: 4px 0 0 4px;
            margin-right: 0;
            display:block;
        }
        .tabs-right>li>a {
            border-radius: 0 4px 4px 0;
            margin-right: 0;
        }
        .sideways {
            margin-top:50px;
            border: none;
            position: relative;
        }
        .sideways>li {
            height: 20px;
            width: 120px;
            margin-bottom: 100px;
        }
        .sideways>li>a {
            border-bottom: 1px solid #ddd;
            border-right-color: transparent;
            text-align: center;
            border-radius: 4px 4px 0px 0px;
        }
        .sideways>li.active>a,
        .sideways>li.active>a:hover,
        .sideways>li.active>a:focus {
            border-bottom-color: transparent;
            border-right-color: #ddd;
            border-left-color: #ddd;
        }
        .sideways.tabs-left {
            left: -50px;
        }
        .sideways.tabs-right {
            right: -50px;
        }
        .sideways.tabs-right>li {
            -webkit-transform: rotate(90deg);
            -moz-transform: rotate(90deg);
            -ms-transform: rotate(90deg);
            -o-transform: rotate(90deg);
            transform: rotate(90deg);
        }
        .sideways.tabs-left>li {
            -webkit-transform: rotate(-90deg);
            -moz-transform: rotate(-90deg);
            -ms-transform: rotate(-90deg);
            -o-transform: rotate(-90deg);
            transform: rotate(-90deg);
        }
        .showTab{
            display: block !important;
        }
        .hideTab{
            display: none !important;
        }
  

打字稿代码: -

selectedUserTab = 1;
   tabs = [
     {
       name: 'Title one',
       key: 1,
       active: true
     },
      {
      name: 'Title two',
      key: 2,
      active: false
    },
    {
      name: 'Title 3',
      key: 3,
      active: false
    },
    {
      name: 'Title Four',
      key: 4,
      active: false
    }
   ];

tabChange(selectedTab) {
    console.log('### tab change');
    this.selectedUserTab = selectedTab.key;
    for (let tab of this.tabs) {
        if (tab.key === selectedTab.key) {
          tab.active = true;
        } else {
          tab.active = false;
        }
    }
  }
  

示例输出

Sample image 注意: - 您需要对css进行一些更改

由于