打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
HBuilder开发App教程04
前言
前几篇说到一些HBuilder开发app的基础教程,
现在来说一下HBuilder开发app的难点,或者说是上手的难点,
就是mui,
如果你没有研究mui就贸然的上手HBuilder,那你的开发过程是痛苦的,
花一点时间研究下mui,对你之后开发app有很大的帮助。
网址
教程再好,也会有疏漏的地方,还需要你仔细阅读官方文档,
附地址:http://dev.dcloud.net.cn/mui/
init
mui封装了很多常用的页面方法,都需要在init中设置,例如:
1.和上拉加载,下拉刷新配套的加载子页面
mui.init({    subpages : [qiao.h.normalPage('list')]});
要想实现上拉加载和下拉刷新,必须使用子页面的方式,需要在init中设置。
2.手势事件和默认事件
长按事件,后退事件,菜单事件,最好在init中设置,
mui.init({    keyEventBind : {        backbutton : false,        menubutton : false    },    gestureConfig : {        longtap:true    }});
等待加载完成
所有的nativejs方法最好都放到等待加载完成后调用,
也就是:
// 所有方法都放到这里mui.plusReady(function(){    window.addEventListener('detailItem', detailItemHandler);});
如果不放到等待nativejs加载完成就执行,那么就会报错。
使用tap而非click
与传统页面不同,所有的手势点击操作都请使用tap,而非click,
这样你的app会有更好的体验。
页面间传值
用html做app,不可避免的是页面间传值,
比较推荐的方法有两种:
1.自定义事件传值
在页面用mui.fire激活自定义事件:
// 查看详情    qiao.on('#todolist li', 'tap', function(){        qiao.h.fire('detail', 'detailItem', {id:$(this).data('id')});    });
在目标页监听自定义事件:
// 所有方法都放到这里mui.plusReady(function(){    window.addEventListener('detailItem', detailItemHandler);});
2.evaljs传值
这种方法不做推荐,但是偶尔也可以使用,
切不可所有传值都用evaljs传值,
在页面调用目标页方法:
qiao.h.indexPage().evalJS('showBackBtn();');
在目标页面定义相应方法:
function showBackBtn(){    $('.menua').removeClass('mui-icon-bars').addClass('mui-icon-back');    $('.adda').hide();}
自定义样式
如果你想自定义app的样式,
很简单只需要定义css样式就好了。
推荐使用css class覆盖原生class的方法自定app样式。
结语
本文虽短,但是很重要,
当你遇到疑难问题,开发不下去的时候,
请回过头来看看是否遵循以上规则,
90%的问题可以迎刃而解。
滴石
官网:http://uikoo9.com/dishi
源码:https://github.com/uikoo9/dishi
http://uikoo9.com/ 更多精彩内容 求打赏(长按图片即可识别)~
捐助列表:http://uikoo9.com/donate/
阅读:21112次
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
如何在Hbuilder中制作app底部导航栏
关于HBuilder使用MUI页面传值
[重磅] 让HTML5达到原生的体验 系列之一 避免切页白屏
HBuilder mui页面间传值的几种方式[转]
mui初级入门教程(一)— 小白入手mui的学习路线
谈谈APP架构选型:React Native还是HBuilder
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服