zoukankan      html  css  js  c++  java
  • 模板预加载子页面

    template(模板页面)

    hello mui示例App中无等待窗体切换的实现是基于模板页面,点击一个链接,不显示雪花等待框,立即打开一个“正在加载...”的页面,之后真实内容快速填充“正在加载...”区域。这种模板页面适用了通用性较强的页面,我们不必要为每个页面创建父子webview,而是将公用的父页面提取出来作为模板页面,同时在页面为加载前可以显示个性化加载页面,可以极大的提升用户体验。模板父页面预加载,点击后立即显示,不用展示雪花等待框,也不会出现白屏现象;共用子页面,有效控制webview数量,避免切页时频繁创建、销毁webview。

    实现思路

    这里我们以列表到详情页的情况为例说明,详情页html结构:

    <ul class="mui-table-view">
        <li class="mui-table-view-cell">
            <a class="mui-navigate-right" href="list1.html">
                Item 1
            </a>
        </li>
        <li class="mui-table-view-cell">
            <a class="mui-navigate-right" href="list2.html">
                 Item 2
            </a>
        </li>
        <li class="mui-table-view-cell">
            <a class="mui-navigate-right" href="list3.html">
                 Item 3
            </a>
        </li>
    </ul>
    

    1.预加载一个模板父页面,用以当页面还没有加载出来的时候展示加载动画,以及作为公用子页面的头部,原理相当于tabbar webview模式的父页面;预加载或者创建一个公用子页面,同时将这个子页面填充到模板父页面;

    // 预加载模板父页面
    var template = mui.preload({
        url:'template.html',
        id:'template',
        styles:{
            popGesture:"hide"
        }
    });
    // 预加载公用子页面
    var subWebview = mui.preload({
        url:'',
        id:'sub_template',
        styles:{
            top: '45px',
        	bottom: '0px'
        }
    });
    // 将子页面填充到父页面
    template.append(subWebview);
    

    2.点击列表链接时,直接显示模板父页面,并动态修改模板父页面的标题;共用子页面通过loadURL方法加载对应目标页面;

    mui('.mui-table-view').on('tap','li a',function(){	
    	var self = this;
    	// 修改共用父模板的标题
    	mui.fire(template, 'updateHeader', {
    		title: self.innerText,
    		href: self.href
    	});
    	// 加载子页面地址
    	if(subWebview.getURL()==self.href){
    	    subWebview.show();
    	}else{
    	    subWebview.loadURL(self.href);
    	    // 子页面加载完成显示
    		subWebview.addEventListener('loaded', function() {
    		    setTimeout(function(){
    		        subWebview.show();  
    		    },50);
    		});	
    	}
    	// 显示模板父页面
    	template.show('slide-in-right', 150);			
    })
    

    3.模板父页面接收参数和返回列表页的处理方法

    var titleElem = document.getElementById("title");
    var contentWebview = null,self = null;
    
    mui.plusReady(function () {
    	self = plus.webview.currentWebview();
    });
    
    // 自定义事件接收参数修改模板父页面头部
    window.addEventListener("updateHeader", function(e) {
    	var title = e.detail.title;
    	var href = e.detail.target;
    	var aniShow = e.detail.aniShow;
    	
    	titleElem.innerHTML = title;
    	titleElem.className = "mui-title mui-fadein";
    	
    	if(mui.os.android&&aniShow&&parseFloat(mui.os.version)>=4.4){
    		if(contentWebview==null){
    			contentWebview = self.children()[0];
    		}
    		if (contentWebview.getURL() != href) {
    			contentWebview.loadURL(href);
    		} else {
    			contentWebview.show();
    		}
    		setTimeout(function () {
    			self.show(aniShow);
    		},10);
    	}
    });
    
    // 返回事件(隐藏模板父页面,并在窗体动画结束后,隐藏共用子页面)
    mui.back = function() {
    	self.hide('auto');
    	setTimeout(function() {
    		titleElem.className = 'mui-title mui-fadeout';
    		titleElem.innerText = '';
    		if(contentWebview==null){
    			contentWebview = self.children()[0];
    		}
    		contentWebview.hide("none");
    	}, 350);
    }
    

    另外需要说明的是,我们这种方式是创建两个webview作为视图容器实现,在web环境下webview的方法不能执行,hello mui里面为每个详情页面创建一个头部,但是我们会发现在app环境下执行并没有出现这个头部,这是以为在hello mui演示demo中的app.css中有这么一段代码:

    .mui-plus.mui-android header.mui-bar{
    	display: none;
    }
    .mui-plus.mui-android .mui-bar-nav~.mui-content{
    	padding: 0;
    }
    

    由于iOS系统性能已经足够好,转场切换不会白屏,hello mui演示demo中iOS没有使用模板页面。当我们引入mui.js文件,在5+环境执行,mui.js会自动将.mui-plus.mui-plus-android类添加到body上,我们可以通过这个方法进行环境判断,是否显示某些内容。
    参考git

  • 相关阅读:
    httpclient5:信任所有证书,调用公众号接口
    驾驶技能考试系统:常见故障原因分析及排除
    C#:Combox实现key,value
    C#:密码框的两种方式
    C#:动态添加或删除控件,并根据控件名称获得控件
    微服务设计模式
    微服务设计模式
    微服务设计模式
    微服务设计模式
    微服务设计模式
  • 原文地址:https://www.cnblogs.com/bonly-ge/p/9644734.html
Copyright © 2011-2022 走看看