ionic實現(xiàn)可滑動的tab選項卡切換效果
利用ionic的slide-box組件實現(xiàn)可滑動的tab,主要是監(jiān)聽tab點擊以及slide頁面滑動的事件,做相應的處理,用ng-repeat循環(huán),優(yōu)化、簡略了代碼,有需要的同學可以看看。
先來張效果圖:
用到的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' : '' "> {vvxyksv9kd} <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){//點擊時候觸發(fā) $scope.slectIndex=index; $ionicSlideBoxDelegate.slide(index); }; $scope.slideChanged=function(index){//滑動時候觸發(fā) $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>
注意點:
•點擊時候?qū)斍把h(huán)的索引$index賦值給變量slideIndex,在tab中使用ng-class判斷點擊時候的索引和slideIndex是否一樣,一樣則改變相應的tab的樣式;
•滑動的時候是用的slide-box的一個函數(shù),on-slide-changed,當slide頁面發(fā)發(fā)生變化的時候,會向改函數(shù)傳遞一個變量index標識當前slide的索引;
•如果不想滾動只點擊,可以去掉on-slide-changed的監(jiān)聽,也可以增加一個屬性,disable-scroll="true",禁止slide page滾動;
如果大家還想深入學習,可以點擊兩個精彩的專題:javascript選項卡操作方法匯總 jquery選項卡操作方法匯總
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關文章
bootstrap treeview 擴展addNode方法動態(tài)添加子節(jié)點的方法
bootstrap-treeview 是一款基于Jquery+bootstrap的樹控件,這篇文章主要介紹了bootstrap treeview 擴展addNode方法動態(tài)添加子節(jié)點的方法,需要的朋友可以參考下2017-11-11在?localStorage?中上傳和檢索存儲圖像的示例詳解
這篇文章主要介紹了在?localStorage?中上傳和檢索存儲圖像,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-06-06javascript一個無懈可擊的實例化XMLHttpRequest的方法
由于IE新舊版本以及與其他瀏覽器在ajax技術上的不同,往往需要對不同的瀏覽器做不同的處理,除了笨拙的瀏覽器嗅探技術,大約也就是對象檢測技術可用了。2010-10-10iframe的onload在Chrome/Opera中執(zhí)行兩次Bug的解決方法
創(chuàng)建iframe對象,添加load事件, 再將iframe添加到body中。Chrome/Opera中會造成load事件的handler執(zhí)行兩次。2011-03-03