丿白开水
丿白开水
  • 发布:2016-12-14 18:18
  • 更新:2016-12-14 18:55
  • 阅读:1173

webview切换问题

分类:HTML5+

mui.init();
var subpages = ['pages/list.html', 'pages/friends.html', 'pages/person.html'];
var subpage_style = { top: "0px", bottom: '52px' };
//创建子页面,首个选项卡页面显示,其它均隐藏;
mui.plusReady(function() {
var self = plus.webview.currentWebview();
for (var i = 0; i < subpages.length; i++) {
var sub = plus.webview.create(subpages[i], subpages[i], subpage_style);
if (i > 0) {
sub.hide();
}
self.append(sub);
}
});
//当前激活选项
var activeTab = subpages[0];
//选项卡点击事件
mui('.index-footer').on('tap', '.index-footer-table', function( e ) {
var targetTab = this.getAttribute('href');
if (targetTab == activeTab) {
return;
}
mui(".index-footer-table").each(function(){
this.classList.remove("index-active");
})
this.classList.add( "index-active" );

            plus.webview.show(targetTab);  
            plus.webview.hide(activeTab);  
            //更改当前活跃的选项卡  
            activeTab = targetTab;  
        });   

这是首页加载源码,我的流程是打开app进入这个首页,person.html下有退出当前账号,进入登录页面重新登录到首页,下面的切换导航就会出现失灵的现象。请问是怎么回事,谢谢了,app等着上线啊

2016-12-14 18:18 负责人:无 分享
已邀请:
Trust

Trust - 少说废话

问题关键在于,重新打开了一个内容同实际的首页相同的webview,而并不是实际的首页窗口对象,所以相关的webview之间的关系并不成立。

目前比较合理的处理方案:
登录完成后,对已经存在(即首页等)的窗口对象中的内容,做出相应的调整(通常是刷新相关数据)。调整结束后,关闭掉登录窗口。

首页

mui.init();  
mui.plusReady(function() {  
    window.addEventListener('loginSuccess', function(e) {  
        var info = e.detail; //获取其它窗口传递过来的参数  
        //TODO 登录成功后,需要刷新部分相关数据,或其它操作;  
        // 操作完成后,关闭登录窗口  
        var loginWv = plus.webview.getWebviewById('login');  
        loginWv && loginWv.close('slide-out-right');  
    });  
});

登录页

mui.init();  
mui.plusReady(function() {  
    // 登录成功  
    var loginInfo = {}; //登录成功后的部分信息  
    var launchWv = plus.webview.getLaunchWebview(); //如果首页不是入口页,则使用id获取;  
    mui.fire(launchWv, 'loginSuccess', loginInfo);  
});

参考相关的API
5+webview
自定义事件

  • 丿白开水 (作者)

    谢谢了。完全解决了我的问题。非常感谢

    2016-12-15 16:57

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