【移動(dòng)端H5開發(fā)】iOS下頁面底部的input被彈出鍵盤遮擋問題

狀況

在iOS下枪眉,如果頁面底部有個(gè)input輸入框,那么在input獲得焦點(diǎn)再层,彈出虛擬鍵盤時(shí)贸铜,有一定的幾率,input會(huì)被虛擬鍵盤給遮擋住聂受,體驗(yàn)很糟糕蒿秦。 尤其是第三方輸入法,這個(gè)出現(xiàn)的幾率極高蛋济。
這其實(shí)已經(jīng)是一個(gè)老生常談的問題棍鳖,從早期的iOS版本一直持續(xù)到現(xiàn)在iOS11都是這樣,感覺上像是iOS的bug,但是不知道為什么一直沒有解決渡处。
打印日志觀察镜悉,發(fā)現(xiàn)鍵盤彈出后,頁面窗口是變矮了医瘫,然后頁面滾動(dòng)到底部侣肄,即使是出現(xiàn)input框被虛擬鍵盤遮擋了,這個(gè)時(shí)候window.innerHeight + document.body.scrollTop 依然是和 document.body.scrollHeight相等的醇份,所以簡(jiǎn)單的對(duì)比這兩個(gè)數(shù)值來判斷頁面是否已經(jīng)滾動(dòng)到了底部是不行的稼锅。
網(wǎng)上查閱了大量的資料,提到了各種各樣的解決辦法僚纷,嘗試了不下10種矩距,基本上都不靠譜,不能最終解決畔濒,最后還是通過定時(shí)器動(dòng)態(tài)調(diào)整scrollTop解決了這個(gè)問題(仍舊不完美)剩晴。

中間踩過的一些坑

  1. 不要用fixed布局锣咒,iOS對(duì)fixed布局的支持比較弱侵状,在虛擬鍵盤彈出的時(shí)候,fixed布局的元素有可能出現(xiàn)各種各樣的問題毅整,建議直接用absolute布局取代
  2. 網(wǎng)上有說改用flex布局可以解決這個(gè)問題趣兄,實(shí)踐發(fā)現(xiàn)壓根沒用,大家可以不用再試
  3. 只調(diào)整一次scrollTop是不夠的悼嫉,最好在1秒內(nèi)調(diào)整多次艇潭,比如每300毫秒調(diào)整一次

解決之道

在input的focus事件中,開啟一個(gè)定時(shí)器戏蔑,然后每隔300毫秒進(jìn)行一次document.body.scrollTop=document.body.scrollHeight的調(diào)整蹋凝,運(yùn)行3次即可。然后在input的blur事件中总棵,取消掉這個(gè)定時(shí)器鳍寂。這樣雖然input不會(huì)被遮擋了,但是由于滾動(dòng)回彈的原因情龄,視覺上會(huì)有頁面回彈的效果迄汛,就是這點(diǎn)不太完美。
參考代碼如下:

var timerId = null; 

onFocus(e) {
  let cnt = 0;
  setInterval( () => {
    if (cnt < 3) {
      cnt++;
    } else {
      clearInterval(timerId);
      timerId = null;
      return;
    }
    document.body.scrollTop = document.body.scrollHeight;
  }, 300);
} 

onBlur(e) {
  if (timerId) {
    clearInterval(timerId);
    timerId = null;
  }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末骤视,一起剝皮案震驚了整個(gè)濱河市鞍爱,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌专酗,老刑警劉巖睹逃,帶你破解...
    沈念sama閱讀 222,000評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異祷肯,居然都是意外死亡沉填,警方通過查閱死者的電腦和手機(jī)粱玲,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,745評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來拜轨,“玉大人抽减,你說我怎么就攤上這事¢夏耄” “怎么了卵沉?”我有些...
    開封第一講書人閱讀 168,561評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)法牲。 經(jīng)常有香客問我史汗,道長(zhǎng),這世上最難降的妖魔是什么拒垃? 我笑而不...
    開封第一講書人閱讀 59,782評(píng)論 1 298
  • 正文 為了忘掉前任停撞,我火速辦了婚禮,結(jié)果婚禮上悼瓮,老公的妹妹穿的比我還像新娘戈毒。我一直安慰自己,他們只是感情好横堡,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,798評(píng)論 6 397
  • 文/花漫 我一把揭開白布埋市。 她就那樣靜靜地躺著,像睡著了一般命贴。 火紅的嫁衣襯著肌膚如雪道宅。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 52,394評(píng)論 1 310
  • 那天胸蛛,我揣著相機(jī)與錄音污茵,去河邊找鬼。 笑死葬项,一個(gè)胖子當(dāng)著我的面吹牛泞当,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播玷室,決...
    沈念sama閱讀 40,952評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼零蓉,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了穷缤?” 一聲冷哼從身側(cè)響起敌蜂,我...
    開封第一講書人閱讀 39,852評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎津肛,沒想到半個(gè)月后章喉,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 46,409評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,483評(píng)論 3 341
  • 正文 我和宋清朗相戀三年秸脱,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了落包。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,615評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡摊唇,死狀恐怖咐蝇,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情巷查,我是刑警寧澤有序,帶...
    沈念sama閱讀 36,303評(píng)論 5 350
  • 正文 年R本政府宣布,位于F島的核電站岛请,受9級(jí)特大地震影響旭寿,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜崇败,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,979評(píng)論 3 334
  • 文/蒙蒙 一盅称、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧后室,春花似錦缩膝、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,470評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至松申,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間俯逾,已是汗流浹背贸桶。 一陣腳步聲響...
    開封第一講書人閱讀 33,571評(píng)論 1 272
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留桌肴,地道東北人皇筛。 一個(gè)月前我還...
    沈念sama閱讀 49,041評(píng)論 3 377
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像坠七,于是被迫代替她去往敵國(guó)和親水醋。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,630評(píng)論 2 359

推薦閱讀更多精彩內(nèi)容