小編給大家分享一下小程序處理鍵盤覆蓋輸入框的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!
專注于為中小企業(yè)提供網(wǎng)站建設(shè)、網(wǎng)站設(shè)計(jì)服務(wù),電腦端+手機(jī)端+微信端的三站合一,更高效的管理,為中小企業(yè)耒陽(yáng)免費(fèi)做網(wǎng)站提供優(yōu)質(zhì)的服務(wù)。我們立足成都,凝聚了一批互聯(lián)網(wǎng)行業(yè)人才,有力地推動(dòng)了上千企業(yè)的穩(wěn)健成長(zhǎng),幫助中小企業(yè)通過(guò)網(wǎng)站建設(shè)實(shí)現(xiàn)規(guī)模擴(kuò)充和轉(zhuǎn)變。在移動(dòng)端里, 當(dāng)輸入框處于頁(yè)面比較下方的時(shí)候回發(fā)生鍵盤覆蓋輸入框的情況, 在小程序中也發(fā)生了類似情況, 但小程序提供了一些api, 但不能達(dá)到需求. 這里來(lái)簡(jiǎn)單說(shuō)一下解決思路.
小程序的默認(rèn)行為
在發(fā)生了鍵盤覆蓋輸入框的時(shí)候, 在不操作任何api的情況下, 小程序會(huì)把屏幕向上推, 推到輸入框正好在鍵盤上方的位置.
也就是如果不經(jīng)過(guò)處理, 小程序的鍵盤是不會(huì)覆蓋輸入框的. 但是在我的需求里這樣還不夠, 因?yàn)轫?yè)面上部分是需要持續(xù)展示的內(nèi)容, 不希望把頁(yè)面向上推.
所以下面要通過(guò)小程序的api來(lái)解決這些問(wèn)題.
cursor-spacing
在比較正常的UI設(shè)計(jì)中, 輸入框外面實(shí)際都會(huì)有一層wrapper, 而很明顯小程序是默認(rèn)行為是不知道的, 所以結(jié)果是會(huì)把這層wrapper的下半部分(輸入框以下的)切掉. 那么就非常難看了.
引入這個(gè)apicursor-spacing, 設(shè)多少, input下面就留多少. 這個(gè)數(shù)字應(yīng)當(dāng)是'輸入框下邊緣到wrapper結(jié)束的距離".
小程序的坑在于: 文檔上的單位是錯(cuò)的, 本來(lái)就需要試才知道這個(gè)屬性的含義是什么, 所以單位錯(cuò)導(dǎo)致無(wú)效果就讓一(大)部分人放棄了. 正確的單位是帶有單位的字符串. 例如10px
或者100rpx
.
adjust-position
剛才說(shuō)到我的需求, 我希望頁(yè)面不向上推, 而直接把輸入框頂上來(lái).
于是嘗試了這個(gè)api. 默認(rèn)是true, 把他設(shè)為false. 效果變成了: 點(diǎn)了輸入框, 鍵盤完美覆蓋輸入框.
于是在加上cursor-spacing, 發(fā)現(xiàn)這兩個(gè)api是不能同時(shí)生效的.
所以最后結(jié)論是: 單純用提供的api無(wú)法實(shí)現(xiàn)需求了. 所以只能監(jiān)聽(tīng)事件自己做.
解決方案
手動(dòng)操作輸入框思路:
adjust-position設(shè)為false.
在輸入框的wrapper的bottom樣式綁到本地?cái)?shù)據(jù), 并設(shè)為absolute定位.
在focus事件里改變輸入框的位置.
在blur事件里復(fù)原輸入框的位置.
按照這個(gè)思路操作, 遇到了幾個(gè)問(wèn)題:
如何確定輸入框的位置
發(fā)現(xiàn)在bindfocus事件中可以獲得鍵盤的高度, 經(jīng)過(guò)嘗試, 鍵盤的高度是以px為單位的. 所以直接把bottom的值設(shè)為px高度就行了.
如果輸入框wrapper的相對(duì)定位不是頁(yè)面底部, 情況就比較復(fù)雜, 若是用rpx為單位, 需要獲得屏幕寬高來(lái)計(jì)算px數(shù), 在不麻煩的情況下可以調(diào)整布局使wrapper相對(duì)于頁(yè)面底部定位.
在改變style后輸入框立即失去焦點(diǎn)
發(fā)生了這個(gè)情況后表現(xiàn)為: 點(diǎn)了輸入框, 輸入框的wrapper閃一下又回原處. (因?yàn)槭ソ裹c(diǎn))
經(jīng)過(guò)多次試驗(yàn), 需要做的是在綁定一個(gè)本地變量到focus
屬性.
然后用wx:if根據(jù)是否focus隱藏輸入框, 放一個(gè)假的輸入框, 點(diǎn)擊以后使改變focus屬性來(lái)喚起鍵盤.
看完了這篇文章,相信你對(duì)小程序處理鍵盤覆蓋輸入框的方法有了一定的了解,想了解更多相關(guān)知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!