1***@qq.com
1***@qq.com
  • 发布:2016-10-25 09:40
  • 更新:2016-10-25 11:53
  • 阅读:1166

webview底部选项卡

分类:MUI

我用webview做的底部选项卡,那一个选项卡能在两个页面之间切换吗?比如“我的”这个选项卡,在登录和个人信息之间切换

2016-10-25 09:40 负责人:无 分享
已邀请:
Trust

Trust - 少说废话

参考Hello mui示例工程中的webview模式选项卡切换。

  • 1***@qq.com (作者)

    那个示例的是选项卡与选项卡之间的切换,我这个是一个选项卡内两个子窗口的切换

    2016-10-25 11:12

dd多了个多

dd多了个多

<script type="text/javascript" charset="utf-8">  
             //mui初始化  
            mui.init();  
            var subpages = ['tab-webview-subpage-about.html', 'tab-webview-subpage-chat.html', 'tab-webview-subpage-contact.html', 'tab-webview-subpage-setting.html'];  
            var subpage_style = {  
                top: '45px',  
                bottom: '51px'  
            };  

            var aniShow = {};  

             //创建子页面,首个选项卡页面显示,其它均隐藏;  
            mui.plusReady(function() {  
                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];  
            var title = document.getElementById("title");  
             //选项卡点击事件  
            mui('.mui-bar-tab').on('tap', 'a', function(e) {  
                var targetTab = this.getAttribute('href');  
                if (targetTab == activeTab) {  
                    return;  
                }  
                //更换标题  
                title.innerHTML = this.querySelector('.mui-tab-label').innerHTML;  
                //显示目标选项卡  
                //若为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');  
                }  
            });  
        </script>
  • 1***@qq.com (作者)

    嗯,我知道你这个,是webview.js里面的,这个是选项卡与选项卡之间的切换,就比如我那个我的选项卡,一开始是个登陆页面,然后点击登陆跳到个人信息页面,那么怎么做这个个人信息页面也被底部选项卡包起来呢

    2016-10-25 12:19

  • dd多了个多

    就是从登陆页面进来直接显示个人页面吗,然后可以切换底部选项卡?

    2016-10-25 13:07

  • 1***@qq.com (作者)

    回复 dd多了个多:不不不,我要的不是切换底部选项卡,嗯,大概的意思就是我上面那一个图那个“我的”选项卡,里面内容是登陆页面,官方给出的点击登陆然后$.openWindow的方法,这样跳转后就只是一个单独的页面,没有底部选项卡了

    2016-10-26 14:49

该问题目前已经被锁定, 无法添加新回复