HBuilder开发App教程04-最难搞定的是mui

原创 2015年07月06日 23:10:47

前言

前几篇说到一些HBuilder开发app的基础教程,

现在来说一下HBuilder开发app的难点,或者说是上手的难点,

就是mui,

如果你没有研究mui就贸然的上手HBuilder,那你的开发过程是痛苦的,

花一点时间研究下mui,对你之后开发app有很大的帮助。


网址

教程再好,也会有疏漏的地方,还需要你仔细阅读官方文档,

附地址:http://dcloudio.github.io/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%的问题可以迎刃而解。


更多教程:

HBuilder开发App教程:http://uikoo9.com/book/detail/3

更多学习笔记:http://uikoo9.com/book

版权声明:本文为博主原创文章,未经博主允许不得转载。

MUI-基础01

如果你没有研究mui就贸然的上手HBuilder,那你的开发过程是痛苦的, 花一点时间研究下mui,对你之后开发app有很大的帮助。 网址 教程再好,也会有疏漏的地方,还...
  • kepoon
  • kepoon
  • 2016年03月18日 22:53
  • 1707

mui.fire()用法

作用:通过mui.fire()方法可以触发目标窗口的自定义事件 mui.fire(目标窗口的webview,'自定义事件名',{参数列表}); 目标窗口监听这个自定义事件 window.addE...
  • sck0088
  • sck0088
  • 2015年07月30日 10:55
  • 13505

H5开发01——mui.fire()触发自定义事件

监听自定义事件 添加自定义事件监听操作和标准js事件监听类似,可直接通过window对象添加,如下: window.addEventListener('customEvent',funct...

WebApp mui&H5+ 视频处理之拍摄

本篇文章介绍WebAPP里如何利用H5+进行拍摄视频。代码加注释 var cmr = plus.camera.getCamera(); ...

HTML5+MUI+HBuilder 之初探情人

MUI(Mobile User Interface)是国内DCloud的最新成果。它遵循了W3C最新的H5+规范,旨在提供一个高效的,跨平台的,H5前端开发框架。本文分享了作者对这项新技术的感受和想法...
  • TBWood
  • TBWood
  • 2014年12月22日 18:19
  • 96984

使用MUI框架构建App请求http接口实例

最近在看Dcloud的MUI框架,MUI封装了android、ios等多个平台的原生接口,达到开发一个项目,采取不同打包方式,生产多种平台的app。无可厚非,对于从事java web开发的工程师,带来...
  • irokay
  • irokay
  • 2016年01月18日 00:57
  • 26792

HTML5+开发移动app教程3-mui开发示例

前言 看了前面两篇内容是否有点跃跃欲试了? 下面就开始一个简答的例子,以及mui相关内容 mui 官网:http://dcloudio.github.io/mui/ 说明:希望你可以...
  • uikoo9
  • uikoo9
  • 2015年02月04日 14:29
  • 104588
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:HBuilder开发App教程04-最难搞定的是mui
举报原因:
原因补充:

(最多只允许输入30个字)