又一次懶癌發作,好久沒有更新博客了。
做過很多移動端的項目,在開發調試過程中,一款好的調試工具會讓效率大大提高。博主之前已經推薦了一款神器:http://www.cnblogs.com/beidan/p/5777476.html
下面,就總結一下移動端遇見的坑。
在國外網站,對這個屬性的兼容性處理,那就是不要設計input的line-height或者設置line-height為normal即可,
試了一下,雖然在谷歌模擬調試里稍微偏上,但是在“真機上”正常垂直居中~
2.line-height
line-height
經常用於文字居中,不同手機顯示效果不一樣。什么鬼~
line-height
加1px,iPhone文字就會稍微‘正常顯示’,由於我們app的ios用戶居多,並且android機型太多,不同機型也會顯示不同,所以只能退而求其次了。line-height的兼容問題不太好解決,容器高度越小,顯示效果的差距越明顯。
解決方案:稍微大一點的高度,最好把line-height設置為高度+1px,兩個平台顯示都不會太‘奇怪’。
3.使用rem (兼容性:ie9+)
一般使用:設置html的font-size為62.5%
1 html {
2 font-size: 62.5%; 3 } 4 body { 5 font-size: 12px; 6 font-size: 1.2rem; 7 } 8 p { 9 font-size: 14px; 10 font-size: 1.4rem; 11 }
4.實現自定義原生控件的樣式
由於select移動端原生樣式很丑,但是原生彈出樣式是符合我們設計的原則
解決方法:將原本select 設置為透明,z-index設置高~再用一個比較好看的樣式‘假裝’在表面
5.移動端使用innerHtml繪制
使用innerHTML繪制大段,之后想獲取HTML的ID節點,事實上是獲取不到的,這種問題在動態創建DOM會經常發生
這也是一個神器的問題,博主自己寫了一個移動端輪播插件,在chrome上瀏覽非常正常,但到了真機上卻顯示空白,各種百度,最后才發現這么坑的地方…
解決方案:嘗試了很多方法之后,老老實實在頁面直接用html結構,如果有更好的方法,也請告訴我。
6.300ms延遲
- 方案一:禁用縮放
meta
標簽時:
- 方案二:更改默認的視口寬度
meta
標簽,那瀏覽器就可以認為該網站已經對移動端做過了適配和優化,就無需雙擊縮放操作了。這個方案相比方案一的好處在於,它沒有完全禁用縮放,而只是禁用了瀏覽器默認的雙擊縮放行為,但用戶仍然可以通過雙指縮放操作來縮放頁面。
7.點擊穿透
問題常見發生場景: 假如頁面上有兩個元素A和B。B元素在A元素之上。我們在B元素的touchstart事件上注冊了一個回調函數,該回調函數的作用是隱藏B元素。我們發現,當我們點擊B元素,B元素被隱藏了,隨后,A元素觸發了click事件。
這是因為在移動端瀏覽器,事件執行的順序是touchstart > touchend > click。
而click事件有300ms的延遲,當touchstart事件把B元素隱藏之后,隔了300ms,瀏覽器觸發了click事件,但是此時B元素不見了,所以該事件被派發到了A元素身上。如果A元素是一個鏈接,那此時頁面就會意外地跳轉。
解決思路:
1.不要混用touch和click
2.消耗掉touch之后的click
解決方法:
1.只用touch 把頁面內所有click全部換成touch事件( touchstart 、’touchend’、’tap’),注意:a標簽的href也是click,需要換成js的跳轉。
2.改動最小——350ms后再隱藏B元素
8. 虛擬鍵盤導致fixed元素錯位
fixed元素一定會伴隨虛擬鍵盤的出現,但是虛擬鍵盤只是“貼”在了viewport上,表面上不會對dom產生“任何”影響,但是這個時候fixed元素表現卻變得怪異起來,會錯位。
解決原理:虛擬鍵盤彈出時將fixed元素設置為static,虛擬鍵盤消失時候設置回來。
解決方案:由於虛擬鍵盤出現並未拋出事件,而檢測scroll或者resize事件,皆會有一定延遲,會出現閃爍現象。則當前獲取焦點元素為文本元素,就將fixed元素設置為static。
9.移動端手勢
手指放在屏幕上:ontouchstart 手指在屏幕上滑動:ontouchmove 手指離開屏幕:ontouchend
原理:
1.在touchstart事件觸發時, 記錄手指按下的時間startTime,本次滑動的初始位置initialPos。
2.在touchmove事件觸發時, 記錄當前位置nowPosition(實時移動元素),滑動距離movePosition(當前位置nowPosition與初始位置initialPos的差值),判斷正負數再決定是左還是右移動。
3.在touchend事件觸發時, 記錄手指離開屏幕的時間endTime,獲得手指在屏幕上停留的時間(endTime-startTime),滑動距離movePosition
- 判斷是否滑動:
- 如果停留時間少於300ms,則認為是快速滑動,無論滑動距離是多少,都到下一頁
- 滑動距離與‘容器’ 大小進行比較,若超過‘容器’大小的1/3,則到下一頁
10.iphone動態生成html元素click失效
如果這篇博客對你有幫助或者有收獲的話,請點擊右下角的推薦,謝謝!