当前位置: 首页 > news >正文

MUI-基础01

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

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


网址

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

附地址:http://dcloudio.github.io/mui/


init

mui封装了很多常用的页面方法,都需要在init中设置,例如:

1.和上拉加载,下拉刷新配套的加载子页面

1
2
3
mui.init({
     subpages : [qiao.h.normalPage( 'list' )]
});

要想实现上拉加载和下拉刷新,必须使用子页面的方式,需要在init中设置。

2.手势事件和默认事件

长按事件,后退事件,菜单事件,最好在init中设置,

1
2
3
4
5
6
7
8
9
mui.init({
     keyEventBind : {
         backbutton :  false ,
         menubutton :  false
     },
     gestureConfig : {
         longtap: true
     }
});


等待加载完成

所有的nativejs方法最好都放到等待加载完成后调用,

也就是:

1
2
3
4
// 所有方法都放到这里
mui.plusReady( function (){
     window.addEventListener( 'detailItem' , detailItemHandler);
});

如果不放到等待nativejs加载完成就执行,那么就会报错。


使用tap而非click

与传统页面不同,所有的手势点击操作都请使用tap,而非click,

这样你的app会有更好的体验。


页面间传值

用html做app,不可避免的是页面间传值,

比较推荐的方法有两种:

1.自定义事件传值

在页面用mui.fire激活自定义事件:

1
2
3
4
// 查看详情
     qiao.on( '#todolist li' 'tap' function (){
         qiao.h.fire( 'detail' 'detailItem' , {id:$( this ).data( 'id' )});
     });

在目标页监听自定义事件:

1
2
3
4
// 所有方法都放到这里
mui.plusReady( function (){
     window.addEventListener( 'detailItem' , detailItemHandler);
});

2.evaljs传值

这种方法不做推荐,但是偶尔也可以使用,

切不可所有传值都用evaljs传值,

在页面调用目标页方法:

1
qiao.h.indexPage().evalJS( "showBackBtn();" );

在目标页面定义相应方法:

1
2
3
4
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


相关文章:

  • CSS 元素垂直居中的 6种方法
  • MUI多端发布开发指南
  • mui 浏览器跨域实现
  • ios网络请求报错:The resource could not be loaded because the App Transport Security policy requires the us
  • iOS 应用将适应新的的IPv6-only网络 -解决方案
  • iOS 开发怎么入门?
  • 如何在Mac OS X上安装 Ruby运行环境
  • iOS CocoaPods安装和使用图解
  • Github上600多个iOS开源项目分类及介绍
  • 使用CocoaPods找不到头文件解决方法
  • 用xib设置圆角,边框和UITextField的私有属性placeholderColor
  • 定制全局的导航栏样式
  • 整理 iOS 9 适配中出现的坑(图文)
  • iOS 应用修改状态栏和导航栏颜色
  • AFNetworking3.1 基本使用
  • 【Amaple教程】5. 插件
  • Angular js 常用指令ng-if、ng-class、ng-option、ng-value、ng-click是如何使用的?
  • angular2开源库收集
  • Angular4 模板式表单用法以及验证
  • ECMAScript入门(七)--Module语法
  • leetcode46 Permutation 排列组合
  • mysql innodb 索引使用指南
  • uni-app项目数字滚动
  • Vue.js源码(2):初探List Rendering
  • 浮动相关
  • 更好理解的面向对象的Javascript 1 —— 动态类型和多态
  • 前端攻城师
  • 使用parted解决大于2T的磁盘分区
  • zabbix3.2监控linux磁盘IO
  • 第二十章:异步和文件I/O.(二十三)
  • 继 XDL 之后,阿里妈妈开源大规模分布式图表征学习框架 Euler ...
  • # 数论-逆元
  • %3cscript放入php,跟bWAPP学WEB安全(PHP代码)--XSS跨站脚本攻击
  • (二十三)Flask之高频面试点
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (附源码)springboot工单管理系统 毕业设计 964158
  • (教学思路 C#之类三)方法参数类型(ref、out、parmas)
  • (九十四)函数和二维数组
  • (强烈推荐)移动端音视频从零到上手(下)
  • (十六)一篇文章学会Java的常用API
  • (一)80c52学习之旅-起始篇
  • (转载)虚幻引擎3--【UnrealScript教程】章节一:20.location和rotation
  • .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
  • .NET Framework Client Profile - a Subset of the .NET Framework Redistribution
  • .NET 反射 Reflect
  • /etc/X11/xorg.conf 文件被误改后进不了图形化界面
  • [ 数据结构 - C++] AVL树原理及实现
  • [2016.7 Day.4] T1 游戏 [正解:二分图 偏解:奇葩贪心+模拟?(不知如何称呼不过居然比std还快)]
  • [202209]mysql8.0 双主集群搭建 亲测可用
  • [AutoSar]状态管理(五)Dcm与BswM、EcuM的复位实现
  • [C/C++]数据结构----顺序表的实现(增删查改)
  • [C++] 统计程序耗时
  • [C++参考]拷贝构造函数的参数必须是引用类型
  • [Django 0-1] Core.Checks 模块
  • [gdc19]《战神4》中的全局光照技术