成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專欄INFORMATION COLUMN

總結(jié)移動(dòng)開發(fā)實(shí)踐中遇到的坑

rockswang / 1497人閱讀

摘要:博主之前已經(jīng)推薦了一款神器下面,就總結(jié)一下移動(dòng)端遇見(jiàn)的坑。解決原理虛擬鍵盤彈出時(shí)將元素設(shè)置為,虛擬鍵盤消失時(shí)候設(shè)置回來(lái)。解決方案由于虛擬鍵盤出現(xiàn)并未拋出事件,而檢測(cè)或者事件,皆會(huì)有一定延遲,會(huì)出現(xiàn)閃爍現(xiàn)象。

做過(guò)很多移動(dòng)端的項(xiàng)目,在開發(fā)調(diào)試過(guò)程中,一款好的調(diào)試工具會(huì)讓效率大大提高。博主之前已經(jīng)推薦了一款神器:http://web.jobbole.com/87587/

下面,就總結(jié)一下移動(dòng)端遇見(jiàn)的坑。

1.input ? placeholder問(wèn)題

在chrome 模擬移動(dòng)端調(diào)試時(shí)[上圖],顯示的非常正常,但是在真機(jī)上[下圖],placeholder里面的內(nèi)容明顯靠上,非常的不美觀

? ??

在國(guó)外網(wǎng)站,對(duì)這個(gè)屬性的兼容性處理,那就是不要設(shè)計(jì)input的line-height或者設(shè)置line-height為normal即可,

試了一下,雖然在谷歌模擬調(diào)試?yán)锷晕⑵希窃凇罢鏅C(jī)上”正常垂直居中~

2.line-h(huán)eight

line-height經(jīng)常用于文字居中,不同手機(jī)顯示效果不一樣。什么鬼~

在chrome模擬器上又是顯示得非常完美,但是!Android和IOS又各自‘偏移’了。如果把line-height加1px,iPhone文字就會(huì)稍微‘正常顯示’,由于我們app的ios用戶居多,并且android機(jī)型太多,不同機(jī)型也會(huì)顯示不同,所以只能退而求其次了。line-height的兼容問(wèn)題不太好解決,容器高度越小,顯示效果的差距越明顯。

解決方案:稍微大一點(diǎn)的高度,最好把line-height設(shè)置為高度+1px,兩個(gè)平臺(tái)顯示都不會(huì)太‘奇怪’。

3.使用rem ?(兼容性:ie9+)

原理:瀏覽器的默認(rèn)字體高都是16px,未經(jīng)調(diào)整的瀏覽器在顯示1em=16px。

rem則是只相對(duì)于根元素的font-size,即只需要設(shè)置根元素的font-size,其它元素使用rem單位設(shè)置成相應(yīng)的百分比即可;

一般使用:

設(shè)置html的font-size為62.5%

html {????
    font-size: 62.5%;
}
body {????
    font-size: 12px;????
    font-size: 1.2rem;
}
p {????
    font-size: 14px;????
    font-size: 1.4rem;
}
4.實(shí)現(xiàn)自定義原生控件的樣式

由于select移動(dòng)端原生樣式很丑,但是原生彈出樣式是符合我們?cè)O(shè)計(jì)的原則

解決方法:將原本select 設(shè)置為透明,z-index設(shè)置高~再用一個(gè)比較好看的樣式‘假裝’在表面

5.移動(dòng)端使用innerHtml繪制

使用innerHTML繪制大段,之后想獲取HTML的ID節(jié)點(diǎn),事實(shí)上是獲取不到的,這種問(wèn)題在動(dòng)態(tài)創(chuàng)建DOM會(huì)經(jīng)常發(fā)生

這也是一個(gè)神器的問(wèn)題,博主自己寫了一個(gè)移動(dòng)端輪播插件,在chrome上瀏覽非常正常,但到了真機(jī)上卻顯示空白,各種百度,最后才發(fā)現(xiàn)這么坑的地方…

解決方案:嘗試了很多方法之后,老老實(shí)實(shí)在頁(yè)面直接用html結(jié)構(gòu),如果有更好的方法,也請(qǐng)告訴我。

6.300ms延遲

方案一:禁用縮放

在HTML文檔頭部包含如下meta標(biāo)簽時(shí):


缺點(diǎn)——就是必須通過(guò)完全禁用縮放來(lái)達(dá)到去掉點(diǎn)擊延遲的目的,然而完全禁用縮放并不是我們的初衷,我們只是想禁掉默認(rèn)的雙擊縮放行為,這樣就不用等待300ms來(lái)判斷當(dāng)前操作是否是雙擊。

方案二:更改默認(rèn)的視口寬度

如果設(shè)置了上述meta標(biāo)簽,那瀏覽器就可以認(rèn)為該網(wǎng)站已經(jīng)對(duì)移動(dòng)端做過(guò)了適配和優(yōu)化,就無(wú)需雙擊縮放操作了。
這個(gè)方案相比方案一的好處在于,它沒(méi)有完全禁用縮放,而只是禁用了瀏覽器默認(rèn)的雙擊縮放行為,但用戶仍然可以通過(guò)雙指縮放操作來(lái)縮放頁(yè)面。

兼容性問(wèn)題:

對(duì)于方案一和方案二,Chrome是率先支持的,F(xiàn)irefox緊隨其后,然而令Safari頭疼的是,它除了雙擊縮放還有雙擊滾動(dòng)操作,如果采用這種兩種方案,那勢(shì)必連雙擊滾動(dòng)也要一起禁用。

7.點(diǎn)擊穿透

問(wèn)題常見(jiàn)發(fā)生場(chǎng)景: 假如頁(yè)面上有兩個(gè)元素A和B。B元素在A元素之上。我們?cè)贐元素的touchstart事件上注冊(cè)了一個(gè)回調(diào)函數(shù),該回調(diào)函數(shù)的作用是隱藏B元素。我們發(fā)現(xiàn),當(dāng)我們點(diǎn)擊B元素,B元素被隱藏了,隨后,A元素觸發(fā)了click事件。

這是因?yàn)樵谝苿?dòng)端瀏覽器,事件執(zhí)行的順序是touchstart > touchend > click。

而click事件有300ms的延遲,當(dāng)touchstart事件把B元素隱藏之后,隔了300ms,瀏覽器觸發(fā)了click事件,但是此時(shí)B元素不見(jiàn)了,所以該事件被派發(fā)到了A元素身上。

如果A元素是一個(gè)鏈接,那此時(shí)頁(yè)面就會(huì)意外地跳轉(zhuǎn)。

解決思路:

1.不要混用touch和click

2.消耗掉touch之后的click

解決方法:

1.只用touch ??把頁(yè)面內(nèi)所有click全部換成touch事件(?touchstart?、’touchend’、’tap’),注意:a標(biāo)簽的href也是click,需要換成js的跳轉(zhuǎn)。

2.改動(dòng)最小——350ms后再隱藏B元素

8. 虛擬鍵盤導(dǎo)致?fixed?元素錯(cuò)位

fixed元素一定會(huì)伴隨虛擬鍵盤的出現(xiàn),但是虛擬鍵盤只是“貼”在了viewport上,表面上不會(huì)對(duì)dom產(chǎn)生“任何”影響,但是這個(gè)時(shí)候fixed元素表現(xiàn)卻變得怪異起來(lái),會(huì)錯(cuò)位。

解決原理:虛擬鍵盤彈出時(shí)將fixed元素設(shè)置為static,虛擬鍵盤消失時(shí)候設(shè)置回來(lái)。

解決方案:由于虛擬鍵盤出現(xiàn)并未拋出事件,而檢測(cè)scroll或者resize事件,皆會(huì)有一定延遲,會(huì)出現(xiàn)閃爍現(xiàn)象。則當(dāng)前獲取焦點(diǎn)元素為文本元素,就將fixed元素設(shè)置為static。

9.移動(dòng)端手勢(shì)

手指放在屏幕上:ontouchstart ? ??手指在屏幕上滑動(dòng):ontouchmove ? ? ?手指離開屏幕:ontouchend

原理:

1.在touchstart事件觸發(fā)時(shí), ?記錄手指按下的時(shí)間startTime,本次滑動(dòng)的初始位置initialPos。

2.在touchmove事件觸發(fā)時(shí), 記錄當(dāng)前位置nowPosition(實(shí)時(shí)移動(dòng)元素),滑動(dòng)距離movePosition(當(dāng)前位置nowPosition與初始位置initialPos的差值),判斷正負(fù)數(shù)再?zèng)Q定是左還是右移動(dòng)。

3.在touchend事件觸發(fā)時(shí), ? 記錄手指離開屏幕的時(shí)間endTime,獲得手指在屏幕上停留的時(shí)間(endTime-startTime),滑動(dòng)距離movePosition

判斷是否滑動(dòng):

如果停留時(shí)間少于300ms,則認(rèn)為是快速滑動(dòng),無(wú)論滑動(dòng)距離是多少,都到下一頁(yè)

滑動(dòng)距離與‘容器’ ?大小進(jìn)行比較,若超過(guò)‘容器’大小的1/3,則到下一頁(yè)

10.iphone動(dòng)態(tài)生成html元素click失效

這個(gè)也是神奇的坑,找了很久資料,也沒(méi)有很原理的解釋。

解決方法: ?為綁定click的元素增加css樣式 ? cursor:pointer;

轉(zhuǎn)載自:http://web.jobbole.com

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/111534.html

相關(guān)文章

  • 分享一些遇到的好文章

    摘要:移動(dòng)端布局總結(jié)移動(dòng)端全兼容的移動(dòng)端知識(shí)涵蓋偽類等全移動(dòng)端不得不講的頭標(biāo)簽移動(dòng)端自適應(yīng)方案移動(dòng)端適配總結(jié)布局新舊混合寫法詳解兼容微信使用實(shí)現(xiàn)手淘頁(yè)面的終端適配淘寶彈性布局方案實(shí)踐理解所需的知識(shí)產(chǎn)生的小數(shù)像素問(wèn)題高性能動(dòng)畫動(dòng)畫的性能優(yōu)化處理和動(dòng) 移動(dòng)端rem布局總結(jié) 移動(dòng)端全兼容的flexbox 移動(dòng)端知識(shí)(涵蓋、css、偽類等)【全】 移動(dòng)端不得不講的頭標(biāo)簽 移動(dòng)端自適應(yīng)方案 移動(dòng)端適...

    Tikitoo 評(píng)論0 收藏0
  • 基于uiwebview富文本編輯器實(shí)踐

    摘要:背景最近我們微信讀書將寫想法換成了基于的富文本編輯器,遇到了不少問(wèn)題,這里我將簡(jiǎn)單的介紹一下我們?cè)陂_發(fā)過(guò)程中踩到的坑。 背景 最近我們微信讀書將寫想法換成了基于webview的富文本編輯器,遇到了不少問(wèn)題,這里我將簡(jiǎn)單的介紹一下我們?cè)陂_發(fā)過(guò)程中踩到的坑。 實(shí)現(xiàn)富文本編輯器有兩個(gè)基本思路: 基于native實(shí)現(xiàn):比如coretext或者textkit 基于uiwebview實(shí)現(xiàn) 第一...

    luzhuqun 評(píng)論0 收藏0
  • 設(shè)計(jì)架構(gòu)

    摘要:先來(lái)看一張系統(tǒng)前后端架構(gòu)模型圖。一種接口的約定本文用于定義一種統(tǒng)一的接口設(shè)計(jì)方案,希望具有參考價(jià)值。,和都是常見(jiàn)的軟件架構(gòu)設(shè)計(jì)模式,它通過(guò)分離關(guān)注點(diǎn)來(lái)改進(jìn)代碼的組織方式。 如何無(wú)痛降低 if else 面條代碼復(fù)雜度 相信不少同學(xué)在維護(hù)老項(xiàng)目時(shí),都遇到過(guò)在深深的 if else 之間糾纏的業(yè)務(wù)邏輯。面對(duì)這樣的一團(tuán)亂麻,簡(jiǎn)單粗暴地繼續(xù)增量修改常常只會(huì)讓復(fù)雜度越來(lái)越高,可讀性越來(lái)越差,有沒(méi)...

    graf 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

閱讀需要支付1元查看
<