ionic實現可滑動的tab選項卡轉場效果,ionictab

來源:互聯網
上載者:User

ionic實現可滑動的tab選項卡轉場效果,ionictab

利用ionic的slide-box組件實現可滑動的tab,主要是監聽tab點擊以及slide頁面滑動的事件,做相應的處理,用ng-repeat迴圈,最佳化、簡略了代碼,有需要的同學可以看看。

先來張:

  

用到的css代碼:

.tab_default{  border-bottom:solid 1px #F2F2F2; padding:6px 0;}.tab_select{ border-bottom:solid 1px #3E89F5; box-shadow:0 -3px 8px #C1D3F0 inset;}.arrow-top { position: absolute; width: 0; height: 0;  top:20px;  border: 6px solid #3E89F5; border-right-color:transparent; border-left-color: transparent; border-top-color: transparent;}.arrow-top:after { content:''; position:absolute; width: 0; height: 0;  border: 12px solid #fff; right: -12px; bottom: -13px; border-right-color:transparent; border-left-color: transparent; border-top-color: transparent;}

頁面上html代碼:

<ion-view view-title="滑動tab">  <ion-content has-bouncing="false"> <div style="display:flex;width:100%;">  <div style="flex:1;text-align: center;" class="tab_default" ng-repeat="d in tabNames" ng-click="activeSlide($index)" ng-class="slectIndex==$index ? 'tab_select' : '' ">   {{d}}   <div class="arrow-top" style="left:{{15+$index*33}}%" ng-show="slectIndex==$index"></div>  </div>  </div>  <ion-slide-box on-slide-changed="slideChanged(index)" active-slide="slideIndex" does-continue="false" show-pager="false">  <ion-slide ng-repeat="p in pages">   <div ng-include="p"></div>  </ion-slide> </ion-slide-box> </ion-content></ion-view>

對應的controller.js代碼:

$scope.tabNames=['java','html5','android'];$scope.slectIndex=0;$scope.activeSlide=function(index){//點擊時候觸發 $scope.slectIndex=index; $ionicSlideBoxDelegate.slide(index);};$scope.slideChanged=function(index){//滑動時候觸發 $scope.slectIndex=index;};$scope.pages=["templates/tab01.html","templates/tab02.html","templates/tab03.html"];

tab01.html、tab02.html、tab03.html這幾個都是差不多的,貼一個tab01的:

<div style="width:100%;text-align: center;padding-top:30px;"> page 01 <p style="margin-top:30px;">  <img src="img/tab01.jpg" style="width:100%;"/> </p></div>

注意點:
 •點擊時候將當前迴圈的索引$index賦值給變數slideIndex,在tab中使用ng-class判斷點擊時候的索引和slideIndex是否一樣,一樣則改變相應的tab的樣式;
 •滑動的時候是用的slide-box的一個函數,on-slide-changed,當slide頁面發發生變化的時候,會向改函數傳遞一個變數index標識當前slide的索引 ;
 •如果不想滾動只點擊,可以去掉on-slide-changed的監聽,也可以增加一個屬性,disable-scroll="true",禁止slide page滾動;

以上就是本文的全部內容,希望對大家的學習有所協助,也希望大家多多支援幫客之家。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.