欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

h5 ios輸入框和鍵盤的兼容性優(yōu)化指南

 更新時間:2018年11月29日 09:23:23   作者:小章魚  
這篇文章主要給大家介紹了關于h5 ios輸入框和鍵盤的兼容性優(yōu)化的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

起因

h5的輸入框引起鍵盤導致體驗不好,目前就算微信、知乎、百度等產(chǎn)品也沒有很好的技術方案實現(xiàn),尤其底部固定位置的輸入框各種方案都用的前提下體驗也并沒有很好,這個問題也是老大難問題了。目前在準備一套與native協(xié)議 來解決這個問題,目前項目中的解決方案還是有值得借鑒的地方的,分享一下

下面話不多說了,來一起看看詳細的介紹吧

業(yè)務場景

固定在h5頁面底部的輸入框

無論是使用

<input />

還是

 <div contenteditable="true">
 </div>

在聚焦事件觸發(fā)調(diào)起原生鍵盤時,在ios部分機型(iphone 4s iphone 5等)上會使得鍵盤彈起后遮擋住輸入框,使得用戶體驗不好。

目前的解決方案是寫一個定時任務,在判定是ios打開頁面時,執(zhí)行以下函數(shù)

let timer = setInterval(()=>{
 // container 知道整個容器的dom節(jié)點
 container.scrollIntoView({ 
 block: 'start',
 behavior: 'auto'
 })
},300); //300毫秒是經(jīng)過多次試驗得到的數(shù)值,用戶體驗為佳

關于scrollIntoView

scrollIntoView這個API,官方的解釋是

The Element.scrollIntoView() method scrolls the element on which it's called into the visible area of the browser window.

語法

element.scrollIntoView(); // 等同于element.scrollIntoView(true) 
element.scrollIntoView(alignToTop); // Boolean型參數(shù) 
element.scrollIntoView(scrollIntoViewOptions); // Object型參數(shù)

參數(shù)

參數(shù) 說明 類型 可選值 默認值
alignToTop -- boolean --- false
scrollIntoViewOptions -- object -- --

{
 behavior: "auto" | "instant" | "smooth",
 block: "start" | "end",
}

在can i use中查到的scrollIntoView的兼容性(主流瀏覽器中不考慮ie)

  • Firefox 36 以上兼容
  • chrome 61 以上兼容
  • safiri 5.1開始 不兼容behavior中的smooth

后續(xù)問題

當然,這個解決方案智能解決部分機型的問題,要真正解決這個問題還是要依靠native端。

在ios 和 安卓機型的問題

因為設置了這個定時任務,就會有一個后續(xù)的問題出現(xiàn),也是在落地項目中有遇到過的,在此說明一下。

在上拉或下拉到頭時,會出現(xiàn)背景白色的現(xiàn)象,因為有了這個定時器,它就會不斷將視圖拉回,導致頁面抖動。
如果在app層做了webview禁止拖動的話就不會有這個問題,當然不能完全依賴app,在程序中我們也需要做此方面的兼容優(yōu)化。

 <div class="container"
   @touchStart="touchStart($event)"
   @touchEnd="touchEnd($event)">
 
 </div>
 touchStart(e) {
 this.clearTimer();
 },
 touchEnd(e) {
 this.repairIosInput();
 },
 clearTimer() {
  if(this.timer) {
   clearInterval(this.timer);
   this.timer = null;
  }else{
   return;
  }
 },
 repairIosInput() {
  if(this.timer) {
   return;
  }
  this.timer = setInterval(()=>{
   container.scrollIntoView({ 
   block: 'start',
   behavior: 'auto'
   })
  },300);
 }

在開始拉動頁面時清空定時器,停止拉動時開啟定時器,這樣就可以解決造成的抖動的問題了。

總結(jié)

做為一個老大難的問題,還會用更多的解決方案,請與我聯(lián)系,一起討論,早日脫坑!

好了,以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。

相關文章

  • IOS安裝包比Android容量大的原因

    IOS安裝包比Android容量大的原因

    這篇文章主要介紹了為什么IOS安裝包比Android容量大的原因,如果你是一個IOS或者安卓開發(fā)者,學習下相關知識吧。
    2018-02-02
  • iOS應用設計模式開發(fā)中職責鏈(責任鏈)模式的實現(xiàn)解析

    iOS應用設計模式開發(fā)中職責鏈(責任鏈)模式的實現(xiàn)解析

    這篇文章主要介紹了iOS應用設計模式開發(fā)中職責鏈模式的相關實現(xiàn)解析,示例代碼為傳統(tǒng)的Objective-C,需要的朋友可以參考下
    2016-03-03
  • iOS實現(xiàn)按鈕點擊選中與被選中切換功能

    iOS實現(xiàn)按鈕點擊選中與被選中切換功能

    這篇文章主要介紹了iOS實現(xiàn)按鈕點擊選中與被選中切換功能,需要的朋友可以參考下
    2017-07-07
  • iOS捕捉截屏事件并展示截圖效果

    iOS捕捉截屏事件并展示截圖效果

    這篇文章主要為大家詳細介紹了iOS捕捉截屏事件并展示截圖效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • CocoaPods1.9.0 安裝使用教程詳解

    CocoaPods1.9.0 安裝使用教程詳解

    CocoaPods是OS X和iOS下的一個第三類庫管理工具,這篇文章主要介紹了CocoaPods1.9.0 安裝使用,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-03-03
  • iOS獲取到用戶當前位置

    iOS獲取到用戶當前位置

    這篇文章主要為大家詳細介紹了iOS獲取到用戶當前位置,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • IOS中無限滾動Scrollview效果

    IOS中無限滾動Scrollview效果

    這篇文章主要為大家詳細介紹了IOS中無限滾動Scrollview效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-02-02
  • ios實現(xiàn)app強制更新功能

    ios實現(xiàn)app強制更新功能

    本篇文章主要介紹了ios實現(xiàn)app強制更新功能,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-05-05
  • iOS自定義時間滾動選擇控件

    iOS自定義時間滾動選擇控件

    這篇文章主要為大家詳細介紹了iOS自定義時間滾動選擇控件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-04-04
  • iOS?WKWebView秒開方案實戰(zhàn)記錄

    iOS?WKWebView秒開方案實戰(zhàn)記錄

    從iOS8開始,就引入了新的瀏覽器控件WKWebView,用于取代UIWebView,下面這篇文章主要給大家介紹了關于iOS?WKWebView秒開方案的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-12-12

最新評論