HBuilder开发App教程04-最难搞定的是mui
前言
前几篇说到一些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
HBuilder开发App教程04-最难搞定的是mui的更多相关文章
- HBuilder开发App教程06-首页
实战 前面几节基本是一些概念的普及, 正如前面提到的,本教程会以滴石作为范例进行解说, 有兴趣的能够先行下载体验一下.或者下载源代码研究下. 新建项目 打开HBuilder,在项目管理器中右键--新建 ...
- HBuilder开发App教程05-滴石和websql
滴石 介绍 滴石是用HBuilder开发的一款计划类app. 用到HBuilder,mui.nativejs以及h5一些特性. 预期 眼下仅仅开发到todolist级别, 以后计划做成日计划,月计划, ...
- Hbuilder开发app实战-识岁06-face++的js实现【完结】
前言 因为识岁app比較简单.所以这节就完结吧, 当然另一些能够优化完好的地方,可是个人兴趣不是非常大, 有想继续完好的,源代码在这里:https://github.com/uikoo9/shisui ...
- Hbuilder开发app实战-识岁03-文件上传
前言 做app不得不谈的问题就是文件上传.用hbuilder开发app让上传变的非常easy. Uploader Uploader模块管理网络上传任务,用于从本地上传各种文件到server,并支持跨域 ...
- HBuilder开发App Step1——环境搭建,HelloMUI 以及真机调试
No1. 必须搭建java环境 只需要最基础的java环境,也就是cmd下可以运行java和javac即可, 具体教程请自行百度,都会有很详细的教程,这里不重点介绍. No2. 下载安装HBuilde ...
- HBuilder开发APP自动登录时跳过"登录页面"
刚接触开发公司APP项目,用HBuilder开发工具. manifest.json中的入口页面就是"登录页面",现在获取到自动登录状态是true,但是真机联调时"登录页面 ...
- hbuilder 开发app 自动升级
使用huilder 开发app ,实现app升级功能 1. var wgtVer = null; //用于获取系统当前版本 var currentversion = null; //用于获取系统最新 ...
- 学用HBuilder开发App的看过来
自己的呕心沥血之作吧,花了一年时间,系统介绍HTML5 App开发的相关技术. 越来越多的公司采用HTML5来快速开发移动跨平台App,它支持当前市场流行的移动设备. 本书主要介绍了HTML5在移动A ...
- 基于 abp vNext 和 .NET Core 开发博客项目 - 用AutoMapper搞定对象映射
上一篇文章(https://www.cnblogs.com/meowv/p/12961014.html)集成了定时任务处理框架Hangfire,完成了一个简单的定时任务处理解决方案. 本篇紧接着来玩一 ...
随机推荐
- 解决BT5不能使用putty连接问题
root@bt:~# cd /etc/sshroot@bt:/etc/ssh# sshd-generate Generating public/private rsa1 key pair.Your i ...
- UCI
数据库是加州大学欧文分校(UniversityofCaliforniaIrvine)提出的用于机器学习的数据库,这个数据库目前共有187个数据集,其数目还在不断增加,UCI数据集是一个常用的标准测试数 ...
- libevent和libev的区别对比(二)
之前有一篇文章描述过一些对比: http://www.cnblogs.com/charlesblc/p/6078029.html 这里在代码和应用方面再说一下. 看一下两边的Helloworld基本就 ...
- BZOJ 3110:[Zjoi2013]K大数查询(整体二分)
http://www.lydsy.com/JudgeOnline/problem.php?id=3110 题意:-- 思路:其实和之前POJ那道题差不多,只不过是换成区间更新,而且是第k大不是第k小, ...
- FatMouse and Cheese 动态化搜索
FatMouse and Cheese Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Othe ...
- Android——init可执行程序
init进程是Android启动后,系统执行的第一个名称为init的可执行程序. 功能: 设备管理 解析启动脚本init.rc 执行启动脚本中的基本功能 执行启动脚本中的各种服务 代码路径:syste ...
- POJ 3186 Treats for the Cows
简单DP dp[i][j]表示的是i到j这段区间获得的a[i]*(j-i)+... ...+a[j-1]*(n-1)+a[j]*n最大值 那么[i,j]这个区间的最大值肯定是由[i+1,j]与[i,j ...
- Java中常用Cache机制的实现
Cache缓存主要分为两类:一.文件缓存:二:内存缓存,也就是实现一个类中静态Map,对这个map进行常规的增删改查: 1.文件缓存 XML格式,序列化DAT文件格式或者其他格式 2.内存缓存
- (简单) POJ 1062 昂贵的聘礼,Dijkstra。
Description 年轻的探险家来到了一个印第安部落里.在那里他和酋长的女儿相爱了,于是便向酋长去求亲.酋长要他用10000个金币作为聘礼才答应把女儿嫁给他.探险家 拿不出这么多金币,便请求酋长降 ...
- android Makefile把jar包打到apk里
这个是经常的需求,我就是经常忘,关键不理解啊. 反反复复的也看看了android makefile. 太复杂了. 慢慢来吧.哎.工作十年.啥也不会.咋整? ## Copyright (C) 2008 ...