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

詳解微信小程序調(diào)起鍵盤性能優(yōu)化

 更新時(shí)間:2018年07月24日 11:45:31   作者:MeloGuo  
這篇文章主要介紹了詳解微信小程序調(diào)起鍵盤性能優(yōu)化,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

在小程序中,我們經(jīng)常有調(diào)起鍵盤的操作場(chǎng)景,但是在不同的場(chǎng)景下解決方案不盡相同,還是需要具體問題具體分析。

需求分析

最近在項(xiàng)目中有一個(gè)需求,是從列表頁點(diǎn)擊評(píng)論按鈕進(jìn)入詳情頁時(shí),在加載完頁面后自動(dòng)調(diào)起鍵盤進(jìn)入評(píng)論狀態(tài)。從需求來看,我們應(yīng)該在onReady函數(shù)中調(diào)起鍵盤,因?yàn)閛nReady函數(shù)是在頁面初次渲染完成時(shí)被調(diào)用。但是在實(shí)踐中我們發(fā)現(xiàn),對(duì)于一些配置不好的手機(jī),其加載頁面速度較慢,在onReady函數(shù)調(diào)用時(shí)頁面并沒有渲染完畢,就會(huì)導(dǎo)致placeholder和input組件位置錯(cuò)亂的現(xiàn)象。其本質(zhì)原因是,onReady生命周期函數(shù)并不能在調(diào)用時(shí)承若已經(jīng)將頁面渲染完成了。(盡管文檔中描述是已經(jīng)完成了。)

之前的操作是在onReady生命周期函數(shù)中調(diào)起鍵盤。

this.setData({ focus: true })

發(fā)現(xiàn)這個(gè)問題后做了相應(yīng)的延遲處理

setTimeout(() => {
 this.setData({ focus: true })
}, 300)

但這是治標(biāo)不治本的方法,手機(jī)性能好的用戶會(huì)無謂的等待300毫秒,而手機(jī)性能很差的用戶等待300毫秒也不一定就能解決這個(gè)問題。

解決思路

那么既然小程序并沒有提供給我們一個(gè)理想的渲染結(jié)束后的回調(diào)函數(shù),那么我們就換個(gè)思路: 使用短輪詢來處理,當(dāng)頁面渲染完成后才調(diào)起鍵盤的操作。

既然要使用短輪詢,那么我們?nèi)ポ喸兪裁茨??什么?biāo)志代表著頁面渲染完成了呢?在這里,我是使用 wx.createSelectorQuery() 方法,它會(huì)返回一個(gè)SelectorQuery對(duì)象實(shí)例,在這個(gè)實(shí)例上調(diào)用select方法選擇我想要去輪詢的節(jié)點(diǎn),在回調(diào)函數(shù)中判斷參數(shù)是否為 null 。如果返回了監(jiān)控的節(jié)點(diǎn)信息,那么說明已經(jīng)渲染完成。這時(shí)就可以進(jìn)行鍵盤調(diào)起操作了。

let timer = setInterval(() => {
 wx.createSelectorQuery().select('#comment-section').boundingClientRect(rect => {
 if (rect !== null && timer !== null) {
  clearInterval(timer)
  timer = null
  this.setData({ focus: true })
 }
 }).exec()
}, 50)

在此之上,如果我們只粗暴的讓 focustrue 并不是個(gè)明智的做法。

在調(diào)起鍵盤時(shí)默認(rèn)頁面會(huì)上推,如果在評(píng)論很少的情況下這樣的體驗(yàn)并不好。所以需要判斷一個(gè)高度,超過這個(gè)值就上推,沒超過就不上推。這個(gè)值視實(shí)際情況而定。 上推的操作是由input組件的 adjust-position 屬性決定,為true則上推,否則則不上推。這時(shí)回調(diào)返回的參數(shù)中的節(jié)點(diǎn)信息就可以派上用場(chǎng)了。

// 在this.setData({ focus: true })前對(duì)節(jié)點(diǎn)高度進(jìn)行判斷
if (rect.height < 500) this.setData({ push: false })
else this.setData({ push: true })

onBlur函數(shù)問題

在實(shí)際的操作中,我們發(fā)現(xiàn)在鍵盤被調(diào)起后會(huì)有概又自動(dòng)收回。經(jīng)過排查發(fā)現(xiàn)時(shí)onBlur函數(shù)的問題,在onBlur函數(shù)中,我們手動(dòng)的設(shè)置 focusfalse ,但其實(shí)并不需要這一步操作,反而帶來了副作用。在我們?nèi)コ诉@部分代碼后,鍵盤自動(dòng)收起的問題得到了解決。

封裝起來

雖然我們完成了這次任務(wù)的需求,但是顯而易見的,這樣的任務(wù)在未來肯定還會(huì)再次出現(xiàn)。所以機(jī)智的我們應(yīng)該趕快把整套流程封裝起來,以便下次直接調(diào)用。

那么這時(shí)我們使用的方式就是這樣的:

const Util = require("xxx") // 引入封裝的庫

/**
 * 生命周期函數(shù)--監(jiān)聽頁面初次渲染完成
 */
onReady: function () {
 Util.onTotalReady('#comment-section', 50, rect => {
 if (rect.bottom < 500) this.setData({ push: false })
 else this.setData({ push: true }}
 this.setData({ focus: true })
 })
}

小結(jié)

在解決鍵盤調(diào)起的這個(gè)過程中我們可以看出微信小程序開發(fā)流程的簡陋,這個(gè)問題的出現(xiàn)本質(zhì)上是小程序提供給我們的生命周期函數(shù)的不夠準(zhǔn)確。否則在頁面渲染完成的情況下我怎么會(huì)拿不到節(jié)點(diǎn)信息呢?像react中的componentWillMount生命周期函數(shù)中就不會(huì)出現(xiàn)這樣的問題,所以希望小程序能再變強(qiáng)大一些,也讓我們少寫一點(diǎn)這種hack代碼。

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • javascript常見操作匯總

    javascript常見操作匯總

    這篇文章主要介紹了javascript常見操作,有針對(duì)字符串、時(shí)間、表單等的操作,以及驗(yàn)證、收藏、隨機(jī)數(shù)等其他常見技巧,需要的朋友可以參考下
    2014-09-09
  • 小程序跨頁面交互的作用與方法詳解

    小程序跨頁面交互的作用與方法詳解

    這篇文章主要介紹了小程序跨頁面交互的作用與方法詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • javascript 精確獲取樣式屬性(下)

    javascript 精確獲取樣式屬性(下)

    繼續(xù)上一部分,我們要看一下顏色?;鸷孟癫还苋叨欢紩?huì)轉(zhuǎn)變?yōu)閞gb格式,不過我們通常比較習(xí)慣的是hex格式。這就用到以下兩函數(shù)。
    2010-01-01
  • JS修改地址欄參數(shù)實(shí)例代碼

    JS修改地址欄參數(shù)實(shí)例代碼

    本文給大家介紹js修改地址欄參數(shù)的實(shí)例代碼,并給大家附上用JS動(dòng)態(tài)改變地址欄內(nèi)容 window.location.href window.location.hash的方法,比較實(shí)用,需要的朋友參考下吧
    2016-06-06
  • js實(shí)現(xiàn)表單項(xiàng)的全選、反選及刪除操作示例

    js實(shí)現(xiàn)表單項(xiàng)的全選、反選及刪除操作示例

    這篇文章主要介紹了js實(shí)現(xiàn)表單項(xiàng)的全選、反選及刪除操作,結(jié)合實(shí)例形式分析了基于dedecms后臺(tái)使用js實(shí)現(xiàn)表單項(xiàng)的全選、反選及刪除相關(guān)操作技巧,需要的朋友可以參考下
    2020-06-06
  • JS學(xué)習(xí)筆記之?dāng)?shù)組去重實(shí)現(xiàn)方法小結(jié)

    JS學(xué)習(xí)筆記之?dāng)?shù)組去重實(shí)現(xiàn)方法小結(jié)

    這篇文章主要介紹了JS學(xué)習(xí)筆記之?dāng)?shù)組去重實(shí)現(xiàn)方法,結(jié)合實(shí)例形式總結(jié)分析了javascript數(shù)組去重的5種常見實(shí)現(xiàn)方法及相關(guān)操作技巧,需要的朋友可以參考下
    2019-05-05
  • 解決layui富文本編輯器圖片上傳無法回顯的問題

    解決layui富文本編輯器圖片上傳無法回顯的問題

    今天小編就為大家分享一篇解決layui富文本編輯器圖片上傳無法回顯的問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • javascript遞歸回溯法解八皇后問題

    javascript遞歸回溯法解八皇后問題

    網(wǎng)上看到許多關(guān)于八皇后算法的文章,很少能看到使用javascript來實(shí)現(xiàn)的,今天就給大家使用javascript來解決下這個(gè)問題,有需要的小伙伴可以參考下。
    2015-04-04
  • Javascript 阻止瀏覽器默認(rèn)操作的實(shí)現(xiàn)代碼

    Javascript 阻止瀏覽器默認(rèn)操作的實(shí)現(xiàn)代碼

    在瀏覽器事件中,會(huì)觸發(fā)一些默認(rèn)動(dòng)作,比如:點(diǎn)擊一個(gè)鏈接時(shí),執(zhí)行完捕獲/冒泡動(dòng)作后,會(huì)觸發(fā)鏈接的默認(rèn)事件:跳轉(zhuǎn)到指定鏈接地址。
    2009-09-09
  • js 輸入框 正則表達(dá)式(菜鳥必看教程)

    js 輸入框 正則表達(dá)式(菜鳥必看教程)

    下面小編就為大家?guī)硪黄猨s輸入框使用正則表達(dá)式校驗(yàn)輸入內(nèi)容的實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-02-02

最新評(píng)論