小程序節(jié)點(diǎn)查詢方法:wx.createSelectorQuery()的使用場(chǎng)景與注意事項(xiàng)

小程序由于內(nèi)置于微信跺株,這使得它有了得天獨(dú)厚的宣傳和使用優(yōu)勢(shì),本著學(xué)習(xí)的心態(tài)空繁,我在官網(wǎng)上看了一遍開發(fā)文檔把敞,大致得出小程序框架的設(shè)計(jì)模式與使用注意事項(xiàng)(重點(diǎn)來了落塑,其實(shí)開發(fā)文檔某些方面敘述的并不仔細(xì)纽疟,甚至存在歧義)。在此與諸君分享憾赁,還望不吝賜教污朽。
0、小程序框架結(jié)構(gòu)就不多贅述有興趣的童鞋可以移步我的博客查看這篇文章龙考,現(xiàn)在要講的是開發(fā)中經(jīng)常需要用到的蟆肆,節(jié)點(diǎn)查詢的API - wx.createSelectorQuery()。
1晦款、使用方法:(從文檔上粘來的栗子炎功,只不過我在上邊添加上了注釋??)
Page({
  queryMultipleNodes: function(){//聲明節(jié)點(diǎn)查詢的方法
    var query = wx.createSelectorQuery()//創(chuàng)建節(jié)點(diǎn)查詢器 query
    query.select('#the-id').boundingClientRect()//這段代碼的意思是選擇Id=the-id的節(jié)點(diǎn),獲取節(jié)點(diǎn)位置信息的查詢請(qǐng)求
    query.selectViewport().scrollOffset()//這段代碼的意思是獲取頁面滑動(dòng)位置的查詢請(qǐng)求
    query.exec(function(res){
      res[0].top       // #the-id節(jié)點(diǎn)的上邊界坐標(biāo)
      res[1].scrollTop // 顯示區(qū)域的豎直滾動(dòng)位置
    })
  }
})
2缓溅、在使用中我遇到了一些問題 - > 總所周知蛇损,在我們移動(dòng)開發(fā)過程中,頁面從創(chuàng)建到加載坛怪,系統(tǒng)給了我們一系列的API去監(jiān)聽這些事件淤齐,小程序也提供了類似的API
0.onLoad - 生命周期函數(shù)--監(jiān)聽頁面加載
1.onReady - 生命周期函數(shù)--監(jiān)聽頁面初次渲染完成
2.onShow - 生命周期函數(shù)--監(jiān)聽頁面顯示

由于app開發(fā)的流程思維,我想當(dāng)然的以為
onload = loadView
onReady = viewDIdLoad
onShow = viewWillAppear

于是在index.js 中我寫下了如下代碼

Page({
  data: {
    motto: 'Hello World',
    userInfo: {},
    hasUserInfo: false,
    canIUse: wx.canIUse('button.open-type.getUserInfo')
  },
  onLoad: function () {
    console.log("0")  
  },
  onShow:function(){
    var query = wx.createSelectorQuery()
    query.select('#myImage').boundingClientRect()
    query.exec(function (res) {
      console.log("1" +res)       // #the-id節(jié)點(diǎn)的上邊界坐
    })
  },
  onReady: function () {
    var query = wx.createSelectorQuery()
    query.select('#myImage').boundingClientRect()
    query.exec(function (res) {
      console.log("2" +res[0])       // #the-id節(jié)點(diǎn)的上邊界坐
    })
  }
})

打印信息如下:


打印信息
分析:

1.由于小程序框架的設(shè)計(jì)為數(shù)據(jù)驅(qū)動(dòng)袜匿,使得事件響應(yīng)方法與我們尋常App開發(fā)中使用的事件響應(yīng)設(shè)計(jì)思路有所不同更啄,它無時(shí)不刻不在關(guān)注著數(shù)據(jù)的變化。所以我們首先應(yīng)該是去適應(yīng)這種數(shù)據(jù)驅(qū)動(dòng)的思維沉帮。
2.方法分析:

       
(1)onload 對(duì)應(yīng)的是加載中锈死,也就是webkit加載頁面的方法執(zhí)行。
(2)onShow 對(duì)應(yīng)的頁面顯示穆壕,并不算是數(shù)據(jù)填充后的顯示待牵,而是“頁面框架的加載”
(3)onReady 指的是“頁面框架的顯示”,而并非頁面數(shù)據(jù)與節(jié)點(diǎn)加載渲染完成喇勋。
(4)微信小程序之所以這么設(shè)計(jì)應(yīng)該是照顧到webkit內(nèi)核壓力的緣故缨该,使得頁面整個(gè)加載分為多個(gè)步驟,異步進(jìn)行川背。
結(jié)論:
  1. 證明他們的執(zhí)行順序是:
    onLoad >> onShow >> onReady
  2. 查詢方法: wx.createSelectorQuery(),在頁面響應(yīng)事件中并不能查詢到節(jié)點(diǎn)信息贰拿。
  3. 如有查詢節(jié)點(diǎn)需求可以用延時(shí)方法或者操作事件來獲取蛤袒。

友情鏈接:

技術(shù)博客 ???????簡(jiǎn)書主頁

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市膨更,隨后出現(xiàn)的幾起案子妙真,更是在濱河造成了極大的恐慌,老刑警劉巖荚守,帶你破解...
    沈念sama閱讀 217,406評(píng)論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件珍德,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡矗漾,警方通過查閱死者的電腦和手機(jī)锈候,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評(píng)論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來敞贡,“玉大人泵琳,你說我怎么就攤上這事√芤郏” “怎么了获列?”我有些...
    開封第一講書人閱讀 163,711評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)势木。 經(jīng)常有香客問我蛛倦,道長(zhǎng)歌懒,這世上最難降的妖魔是什么啦桌? 我笑而不...
    開封第一講書人閱讀 58,380評(píng)論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮及皂,結(jié)果婚禮上甫男,老公的妹妹穿的比我還像新娘。我一直安慰自己验烧,他們只是感情好板驳,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著碍拆,像睡著了一般若治。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上感混,一...
    開封第一講書人閱讀 51,301評(píng)論 1 301
  • 那天端幼,我揣著相機(jī)與錄音,去河邊找鬼弧满。 笑死婆跑,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的庭呜。 我是一名探鬼主播滑进,決...
    沈念sama閱讀 40,145評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼犀忱,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了扶关?” 一聲冷哼從身側(cè)響起阴汇,我...
    開封第一講書人閱讀 39,008評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎节槐,沒想到半個(gè)月后鲫寄,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡疯淫,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評(píng)論 3 334
  • 正文 我和宋清朗相戀三年地来,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片熙掺。...
    茶點(diǎn)故事閱讀 39,795評(píng)論 1 347
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡未斑,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出币绩,到底是詐尸還是另有隱情蜡秽,我是刑警寧澤,帶...
    沈念sama閱讀 35,501評(píng)論 5 345
  • 正文 年R本政府宣布缆镣,位于F島的核電站芽突,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏董瞻。R本人自食惡果不足惜寞蚌,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評(píng)論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望钠糊。 院中可真熱鬧挟秤,春花似錦、人聲如沸抄伍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽截珍。三九已至攀甚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間岗喉,已是汗流浹背秋度。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沈堡,地道東北人静陈。 一個(gè)月前我還...
    沈念sama閱讀 47,899評(píng)論 2 370
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親鲸拥。 傳聞我的和親對(duì)象是個(gè)殘疾皇子拐格,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評(píng)論 2 354

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

  • 給提問的開發(fā)者的建議:提問之前先查詢 文檔、通過社區(qū)右上角搜索搜索已經(jīng)存在的問題刑赶。 寫一個(gè)簡(jiǎn)明扼要的標(biāo)題捏浊,并且...
    極樂叔閱讀 13,437評(píng)論 0 3
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn)撞叨,斷路器金踪,智...
    卡卡羅2017閱讀 134,654評(píng)論 18 139
  • Android 自定義View的各種姿勢(shì)1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 172,110評(píng)論 25 707
  • 其實(shí)我對(duì)自己的了解并不多 有時(shí)候真的不知道自己到底是個(gè)什么樣的人 別人會(huì)問我 你是不是很開心 我說對(duì)呀 他們會(huì)說怎...
    我叫薛三歲閱讀 207評(píng)論 0 0