JavaScript   发布时间:2022-04-16  发布网站:大佬教程  code.js-code.com
大佬教程收集整理的这篇文章主要介绍了ionic实现可滑动的tab选项卡切换效果大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。

利用ionic的slide-box组件实现可滑动的tab,主要是监听tab点击以及slide页面滑动的事件,做相应的处理,用ng-repeat循环,优化、简略了代码,有需要的同学可以看看。

先来张效果图:

ionic实现可滑动的tab选项卡切换效果

用到的css代码:

{ 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代码:

View view-@R_262_10283@e="滑动tab"> false">
:100%;">
:1;text-align: center;" class="tab_default" ng-repeat="d in tabNames" ng-click="activeSlide($indeX)" ng-class="slecTindex==$index ? 'tab_SELEct' : '' "> {{D}}
{{15+$index*33}}%" ng-show="slecTindex==$index">
X)" active-slide="slideIndex" does-conTinue="false" show-pager="false">

对应的controller.js代码:

Tindex=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的:

:100%;text-align: center;padding-top:30px;"> page 01

:100%;"/>

注意点:

•点击时候将当前循环的索引$index赋值给变量slideIndex,在tab中使用Ng-class判断点击时候的索引和slideIndex是否一样,一样则改变相应的tab的样式; •滑动的时候是用的slide-box的一个函数,on-slide-changed,当slide页面发发生变化的时候,会向改函数传递一个变量index标识当前slide的索引 ; •如果不想滚动只点击,可以去掉on-slide-changed的监听,也可以增加一个属性,disable-scroll="true",禁止slide page滚动;

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持菜鸟教程。

大佬总结

以上是大佬教程为你收集整理的ionic实现可滑动的tab选项卡切换效果全部内容,希望文章能够帮你解决ionic实现可滑动的tab选项卡切换效果所遇到的程序开发问题。

如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。