用了MUI以後,才發現,那坑比我想象之中的要多得多,有些是H5的坑,有些是plus的坑,接下來我一一來吐槽一番。css
這種狀況,在Android下面是正常的。why?ios
由於mui框架的頭部header和底部nav都是採用的fixed佈局css3
<header id="header" class="mui-bar mui-bar-nav action-head"
而IOS下面壓根就不支持fixed佈局,因此嘍就杯具了,這個問題還體如今另外一種狀況下。那就是當頁面中的內容很長超出了一屏,並且頁面中存在文本框,這個時候若是咱們文本框一聚焦,在ios下面會自動滾動,軟鍵盤會彈出來,這時若是你上拉下拉操做,fixed佈局的部分就漂浮了。web
個人解決方案json
拋棄mui中舊的openWindow和openWindowWithTitle,採用最新的titleNView瀏覽器
owner.openWindowWithTitle = function (WebviewOptions, title) { var _styles = { // 窗口參數 參考5+規範中的WebviewStyle,也就是說WebviewStyle下的參數均可以在此設置 titleNView: { // 窗口的標題欄控件 titleText: title, // 標題欄文字,當不設置此屬性時,默認加載當前頁面的標題,並自動更新頁面的標題 titleColor: "#fff", // 字體顏色,顏色值格式爲"#RRGGBB",默認值爲"#000000" titleSize: "17px", // 字體大小,默認17px backgroundColor: "#449DED", // 控件背景顏色,顏色值格式爲"#RRGGBB",默認值爲"#F7F7F7" progress: { // 標題欄控件的進度條樣式 color: "#56CF87", // 進度條顏色,默認值爲"#00FF00" height: "2px" // 進度條高度,默認值爲"2px" }, splitLine: { // 標題欄控件的底部分割線,相似borderBottom color: "#CCCCCC", // 分割線顏色,默認值爲"#CCCCCC" height: "0px" // 分割線高度,默認值爲"2px" }, autoBackButton: true }, }; WebviewOptions.styles = _styles; mui.openWindow(WebviewOptions); }
爲何官方提供的Demo沒有這樣的現象,說到這裏,內心就火,官方提供的demo,限制了上拉下拉的速度,很慢的,因此天然沒法出現表頭在ios下面自動隱藏的狀況,並且也沒有這個長屏幕輸入文本框的狀況。但是官方沒有給出任何說明,這纔是最坑的。緩存
其它問題:這裏的返回圖標的大小沒法設置。H5+文檔中沒有找到相關設置的地方,我暈。app
一開始,我直接是經過修改manifest.json的配置來進行修改的,怎知Android下面是能夠了,可是ios下面無效。plus節點下面添加以下配置,將狀態欄設置爲藍色背景。框架
"plus": { "launchwebview":{"statusbar":{"background":"#449DED"}}, "statusbar":{"background":"#449DED"},/*狀態欄*/
爲了在IOS中全部頁面中修改狀態欄顏色,我在一個公共的js文件中添加了以下代碼:佈局
document.addEventListener('plusready', function () { plus.navigator.setStatusBarBackground("#449DED");// 設置系統狀態欄背景爲藍色 plus.navigator.setStatusBarStyle("UIStatusBarStyleBlackOpaque");// 設置系統狀態欄樣式爲淺色文字 }, false);
OK,問題解決。
爲何官網給的Demo沒問題?由於那Demo太簡單了,實在是沒法模擬真實的應用場景。
我目前的解決辦法:判斷當主界面的數據大於2條時,這是由於我這裏大於2條時會出現滾動條,我自動設置主界面的高度+1px,這樣作是爲了產生垂直滾動條,而後在全部觸發這個滾動彈出層的地方,添加以下代碼:(好比說點擊狀態、或者點擊報修部門的時候)
isEmptyScroll = true; window.scrollTo(1, 1);
加載數據列表的代碼
if (app.$data.list.length <= 2) { if (isEmptyScroll) { g.id("pullrefresh").style.height = g.getScreenInfo('height') +1 + 'px'; } } else { g.id("pullrefresh").style.height = 'auto'; } isEmptyScroll = false;
公共js代碼:
/** * 得到屏幕的高度 * @param {Object} element */ owner.getScreenInfo = function (element) { if (element == 'width') { return document.documentElement.clientWidth || document.body.clientWidth; } else { return document.documentElement.clientHeight || document.body.clientHeigth; } };
聽說採用雙webview的話不會出現這種問題,我暫時沒有去實驗過,但是官方又推薦使用單webview的方式,說雙webview太耗性能並且使用沒那麼方便。很操蛋啊,我天然是優先採用官方推薦的方式哇!
按照H5+的方式去操做,IOS下面能取到值,可是Android無效。
//清除緩存 document.getElementById('clearCache').addEventListener('tap', function() { mui.confirm('圖片及離線緩存的內容將會被刪除', '肯定刪除全部緩存?', btnArray, function(e) { if(e.index == 1) { plus.cache.clear(function() { mui.toast("應用緩存清除成功!"); }); } }); });
獲取緩存大小
mui.plusReady(function() {
//獲取緩存大小 var _result = ''; plus.cache.calculate(function(size) { _result = g.bytesToSize(size); console.log(_result) document.getElementById("cacheSize").innerText =_result; });
});
公共方法:
//字節轉換爲KB等大小 owner.bytesToSize = function (bytes) { if (bytes === 0) return '0 B'; var k = 1024; sizes = ['B', 'KB', 'MB', 'GB', 'TB', 'PB', 'EB', 'ZB', 'YB']; i = Math.floor(Math.log(bytes) / Math.log(k)); var _size = (bytes / Math.pow(k, i)); return _size.toFixed(2) + ' ' + sizes[i]; }
目前暫時沒有想到什麼好的辦法解決。
因爲我這個動畫特效是採用的css3,因此很容易想到是瀏覽器樣式不兼容引發的。其實就是添加-webkit-前綴來指定。由於移動端許多瀏覽器都是webkit內核。
HTML
<div class="portrait-clockin fr"> <div class="dot" v-on:tap="doPunchCard()"> <div class="dot2"> <div class="dot3"> <ul> <li class="one fl" v-text="nowTime"></li> <li class="fl">打卡</li> </ul> </div> </div> </div> </div>
css樣式:
.portrait-clockin{width: 3rem;height: 3rem;margin: 0 15px 0px 0px;} .fr { float: right; } /*上班打卡 水波紋效果*/ a.dot:active,a.dot2:active,a.dot3:active{background: #70a236;} .dot { animation: sploosh 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); -webkit-animation:sploosh 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); } .dot2 { animation: sploosh2 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); -webkit-animation:sploosh2 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); } .dot3 { animation: sploosh3 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); -webkit-animation:sploosh3 1.5s cubic-bezier(0.165, 0.84, 0.44, 1); } .dot ul{margin: 0px;padding: 0px;width: 100%;margin: 0.65rem 0px;} .dot li{width: 100%;font-size: 0.48rem;line-height: 0.5rem;height: 0.5rem;} .dot li.one{font-size: 0.4rem;line-height: 0.8rem;height: 0.8rem;} .dot,.dot2,.dot3{ height: 96px;width: 96px; font-size: 20px;color: #fff;line-height: 96px;text-align: center;border-radius: 100%; position: absolute;z-index: 1;animation-iteration-count:infinite; -webkit-animation-iteration-count:infinite;background: transparent; } @keyframes sploosh { 0% {box-shadow: 0 0 0 0px rgba(158, 203, 244, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {box-shadow: 0 0 0 10px rgba(158, 203, 244, 0);background: rgba(84, 166, 240, 0);} } @keyframes sploosh2 { 0% { box-shadow: 0 0 0 0px rgba(110, 179, 243, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {box-shadow: 0 0 0 6px rgba(110, 179, 243, 0);background: rgba(84, 166, 240, 0.3);} } @keyframes sploosh3 { 0% {box-shadow: 0 0 0 0px rgba(255, 255, 255, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {box-shadow: 0 0 0 2px rgba(255, 255, 255, 0); background: rgba(84, 166, 240, 1);} } @-webkit-keyframes sploosh { 0% {-webkit-box-shadow: 0 0 0 0px rgba(158, 203, 244, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {-webkit-box-shadow: 0 0 0 10px rgba(158, 203, 244, 0);background: rgba(84, 166, 240, 0);} } @-webkit-keyframes sploosh2 { 0% {-webkit-box-shadow: 0 0 0 0px rgba(110, 179, 243, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {-webkit-box-shadow: 0 0 0 6px rgba(110, 179, 243, 0);background: rgba(84, 166, 240, 0.3);} } @-webkit-keyframes sploosh3 { 0% {-webkit-box-shadow: 0 0 0 0px rgba(255, 255, 255, 0.7);background: rgba(84, 166, 240, 0.7);} 100% {-webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0); background: rgba(84, 166, 240, 1);} } /*波紋結束*/
圓點效果以下:
我以前的作法:
<span v-if="item.rad" href="#" class="round">●</span>
CSS代碼以下:
/*小圓點*/ .round { width: 6px;height: 6px;display: -webkit-inline-box;font-size: 7px;margin-left: -2px; line-height: 6px;text-align: center;color: #FD7777;text-decoration: none;position: absolute;top: 5px; }
結果我發現,在IOS下面這個小圓點是在是過小了,並且不管你怎麼修改樣式的寬和高都無效。
後來的作法:
HTML代碼結構以下, class="round"部分
<a v-for="(item,index) in menus" v-on:tap="getTaskList(item.name)" class="mui-control-item" v-bind:id="item.id" v-bind:class="{'mui-active': !index}"> <span v-text="item.title"></span>(<span v-text="item.taskNum"></span>) <span v-if="item.rad" href="#" class="round"></span> </a>
CSS代碼以下:
/*小圓點*/ .round { border-radius:50%;width: 6px;height: 6px;display: -webkit-inline-box;font-size: 6px;margin-left: -2px; line-height: 6px;text-align: center;background-color: #FD7777;text-decoration: none;position: absolute;top: 5px; }
HBuilder隔三差五的就會發布新的補丁,而後你天天打開的時候,它就會自動彈出提示框,提示你是否更新,若是你一不當心點擊了更新,那你最好先看看補丁解決了哪些問題,看一下它的更新日誌。
而後必定要記得的是,要去更新你項目中mui.js、mui.css等等這些你項目中引用了的文件。如何更新呢?能夠在最新的HBuilder中新建一個mui項目,而後把項目中的js和css文件拷貝過來。由於每一次打補丁,你很難肯定它是否只修改了基座,仍是其它mui相關的css或者js都有修改,因此保險的作法就是一塊兒更新。還有個問題須要注意的是,每一次補丁升級,都有可能改出新的問題,因此在更新以前,建議先備份全部代碼,或者給代碼打一個標籤。
mui官方demo中提供了圖片縮放功能,其實這裏有須要注意的地方,若是須要用到圖片縮放的界面中,存在文本框等須要輸入和編輯的地方,會讓你輸入和編輯無效。也就是說你圖片縮放只能在詳情這種只須要展現的場景下使用,而官方是不會告訴你這些的,只有你被碰得頭破血流,纔會感到多麼痛的領悟!
暫時就先吐槽這麼多,其它的問題還有不少....