h5+app页面间的传值

在App开发中,经常会遇到页面间传值的需求,比如从新闻列表页进入详情页,需要将新闻id传递过去; Html5Plus规范设计了evalJS方法来解决该问题; 但evalJS方法仅接收字符串参数,涉及多个参数时,需要开发人员手动拼字符串; 为简化开发,mui框架在evalJS方法的基础上,封装了自定义事件,通过自定义事件,用户可以轻松实现多webview间数据传递。因为是多webview之间传值,故无法在手机浏览器、微信中使用;
添加自定义事件监听操作和标准js事件监听类似,可直接通过window对象添加,如下:

window.addEventListener(‘customEvent’,function(event){
//通过event.detail可获得传递过来的参数内容

});
通过mui.fire()方法可触发目标窗口的自定义事件:
mui.fire(detailPage,‘newsId’,{})

//初始化预加载详情页面
mui.init({
preloadPages:[{
id:‘detail.html’,
url:‘detail.html’
}
]
});
用了这个后可以这样打开页面
mui.openWindow({
id:‘detail.html’
});

	var detailPage = null;
	//添加列表项的点击事件
	mui('.mui-content').on('tap', '.mui-slider', function(e) {
		var id = this.getAttribute('id');
		//获得详情页面
		if(!detailPage) {
			detailPage = plus.webview.getWebviewById('detail.html');
		}
		//触发详情页面的newsId事件
		mui.fire(detailPage, 'newsId', {
			id: id
		});
		//打开详情页面          
		mui.openWindow({
			id: 'detail2.html'

		});
	});

详情页面代码如下:
//添加newId自定义事件监听

window.addEventListener('newsId',function(event){
  //获得事件参数
  var id = event.detail.id;
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值