IOS在Input失焦后,發現body的頁面會停止不下來,並且頁面上的輸入框,按鈕點擊事件,全部都移位了,需要滑動一下才可以正常。
下面是解決方法,可全局引用:
var u = navigator.userAgent; var flag; var myFunction; var isIOS = !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/); if (isIOS) { document.body.addEventListener('focusin', () => { //軟鍵盤彈起事件 flag = true; clearTimeout(myFunction); }) document.body.addEventListener('focusout', () => { //軟鍵盤關閉事件 flag = false; if (!flag) { myFunction = setTimeout(function () { window.scrollTo({ top: 0, left: 0, behavior: "smooth" })//重點 =======當鍵盤收起的時候讓頁面回到原始位置(這里的top可以根據你們個人的需求改變,並不一定要回到頁面頂部) }, 200); } else { return } }) } else { return }
引自:https://www.javascriptcn.com/read-52084.html