mui开发APP教程之使用选项卡跳转子页面

首页HTML代码:

<!--主页面底部选项卡-->
<nav class="mui-bar mui-bar-tab">
    <a id="defaultTab" class="mui-tab-item mui-active" href="html/index-sub-home.html">
        <span class="mui-icon mui-icon-home"></span>
        <span class="mui-tab-label">
            首页
        </span>
    </a>
    <a class="mui-tab-item" href="html/index-sub-classify.html">
        <span class="mui-icon mui-icon-list"></span>
        <span class="mui-tab-label" >
            分类
        </span>
    </a>
    <a class="mui-tab-item" href="html/index-sub-shopCart.html">
        <span class="mui-icon iconfont icon-cart">
            <span class="mui-badge" id="shopCartCount">2</span>
        </span>
        <span class="mui-tab-label">
            购物车
        </span>
    </a>
    <a class="mui-tab-item" href="html/index-sub-person.html">
        <span class="mui-icon mui-icon-person"></span>
        <span class="mui-tab-label" >
            我的
        </span>
    </a>
</nav>

js代码:

mui.plusReady(function() {
    //要切换的子页面
    var subpages=[
    'html/index-sub-home.html',
    'html/index-sub-classify.html',
    'html/index-sub-shopCart.html',
    'html/index-sub-person.html'];
    //子页面样式,这里只有主页的底部是公用的,所以距离底部51个px,距离顶部0个px
    var subpage_style = {
        top: '0px',
        bottom: '51px'
    };

    var aniShow = {};

    var self = plus.webview.currentWebview();

    for (var i = 0; i < 4; i++) {
        var temp = {};
        var sub = plus.webview.create(subpages[i],subpages[i],subpage_style,{});
        if (i > 0) {
            sub.hide();
        }else{
            temp[subpages[i]] = "true";
            mui.extend(aniShow,temp);
        }
        self.append(sub);
    }
    //当前激活选项
    var activeTab = subpages[0];

    //选项卡点击事件
    mui('.mui-bar-tab').on('tap', 'a', function(e) {
        var targetTab = this.getAttribute('href');
        if (targetTab == activeTab) {
            return;
        }

        //显示目标选项卡
        //若为iOS平台或非首次显示,则直接显示
        if(mui.os.ios||aniShow[targetTab]){
            plus.webview.show(targetTab);
        }else{
            //否则,使用fade-in动画,且保存变量
            var temp = {};
            temp[targetTab] = "true";
            mui.extend(aniShow,temp);
            plus.webview.show(targetTab,"fade-in",300);
        }
        //隐藏当前;
        plus.webview.hide(activeTab);
        //更改当前活跃的选项卡
        activeTab = targetTab;
    });
    //自定义事件,模拟点击“首页选项卡”   
    //即一加载的时候就显示默认的子页面,不然在点击选项卡之前,除了底部选项卡是一片空白
    document.addEventListener('gohome', function() {
        var defaultTab = document.getElementById("defaultTab");
        //模拟首页点击
        mui.trigger(defaultTab, 'tap');
        //切换选项卡高亮
        var current = document.querySelector(".mui-bar-tab>.mui-tab-item.mui-active");
        if (defaultTab !== current) {
            current.classList.remove('mui-active');
            defaultTab.classList.add('mui-active');
        }
    });
});
  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值