使用mui开发h5+app中遇到的技术问题总结
2018年12月我开始着手做一个车生活app的项目,到现在除去春节放假也有两个月的时间,从开始对app开发一无所知,到后来制作出一个相对完整的版本。中间学习了很多也遇到了很多问题,现在对中间的技术问题进行总结。
一.学习mui框架
之前做过webapp,vue用过一段时间,做过小程序,但是这种独立的h5+app还没有玩过。mui是我接触的第一个接近原生效果的手机端ui框架,之前看过一点,但是没有在实战中用过。
1.mui的官网文档让人诟病的一点就是不够完善,诸如mui-modal这样很多组件的用法在文档中都是没有的,需要在官方demo中仔细查找。
2.dtpicker选择器:在一个页面放置多个dtpicker选择器只有第一个生效但是后面几个不弹出。找了半天没有找到原因,后来发现把选择器改为document.querySelector()就可以了。
3.mui.fire():通过plus.webview.getWebviewById( id );来获取指定页面的id;console.log出plus.webview.all();获取所有的窗口,取得数组对象,查看目标窗口的路径。
二.html5+API Reference
(1)调取高德地图api实现地图搜索导航与地图选点导航功能:
map.js完整代码1 map.js完整代码2 map.js完整代码3 map.js完整代码4(2)车型选择功能
功能页面 根据字母顺序排序,选择车型针对这种车型选择功能,借鉴了第三方平台的代码。现在对功能实现进行了总结:
1.车型数据获取,数据的获取主要是通过从制定url抓取的数据,不做多说。
2.根据字母顺序排序,选择车型:在这里引用了mui.simpledlist.js。链接: https://pan.baidu.com/s/1FIuW1DzpZ2fGAogaiuUWuw 提取码: n8xf
(3)nativeUi
1.使用原生nativeui的样式组件:
nativeUi api2.对于ajax规范化书写;
在原来的项目中一直都没有对ajax做过非常规范化的处理,在这里学习了大佬的经验,对ajax进行了规范化的处理,对于项目的运行和确认前后端错误有好处。
一个完整的ajax备注:APP_DOMAIN为自定义服务器地址; mklog()为下列函数;
mklog()函数3.省份选择:使用mui-modal
省份选择链接:https://pan.baidu.com/s/1pN2DHrXf_VCIR_Hd7Y0d5Q 提取码:xmbi
4.字符串拼接,动态创建节点 的新方式
之前从后台获取数据之后都是使用字符串拼接的方式动态的创建节点,但是这种方式的局限在于非常繁琐,es6使用``之后不用考虑引号的问题,但是仍然存在一个变量写错而影响整体性能的问题。在这里改用了一种新的方式去拼接字符串创建节点:
artTemplate >>> javascript模板引擎
模板调试器可以精确定位到引发渲染错误的模板语句,解决了编写模板过程中无法调试的痛苦,让开发变得高效,也避免了因为单个模板出错导致整个应用崩溃的情况发生。
模板引擎性能测试 采用模板引擎之后的渲染方式