Vue如何實現(xiàn)監(jiān)聽組件原生事件
在首頁開發(fā)中,右下角有一個返回頂部的小箭頭,將它單獨封裝成一個BackTop組件,但是它何時出現(xiàn)需要依賴于首頁的滑動,即另外一個Scroll組件。如果直接在BackTop組件里面監(jiān)聽,則需要通過this.$emit將事件發(fā)射到Home組件中,又在Home中監(jiān)聽自定義事件,比較復(fù)雜。因此,我們直接在Home中對BackTop組件進(jìn)行監(jiān)聽,使用 .native
官網(wǎng)對于native的解釋為:
.native:監(jiān)聽組件根元素的原生事件
代碼如下:
在Home.vue中對back-top組件進(jìn)行點擊事件監(jiān)聽:
this.$refs.scroll 得到的是 Scroll 組件,this.$refs.scroll.scroll 得到的是Scroll組件中 data 中定義的 scroll屬性,
better-scroll中有個方法是 scrollTo,
這里順便講解一下 ref 屬性的使用:
ref 被用來給DOM元素或子組件注冊引用信息。引用信息將會注冊在父組件的 $refs對象上。$refs 是所有注冊過的ref的一個集合,
如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子組件上,引用就指向組件實例。
1.在普通的dom結(jié)構(gòu)中,在元素上添加ref屬性,this.$refs.ref獲取的是具有這個ref屬性的dom節(jié)點
2.在vue組件中,this.$refs.ref獲取的是組件的實例,組件中的data可以直接this.$refs.ref.key獲取數(shù)據(jù)
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 輕松學(xué)習(xí)XML教程2. jsp實現(xiàn)登錄驗證的過濾器3. css代碼優(yōu)化的12個技巧4. jsp+servlet簡單實現(xiàn)上傳文件功能(保存目錄改進(jìn))5. 利用FastReport傳遞圖片參數(shù)在報表上展示簽名信息的實現(xiàn)方法6. xpath簡介_動力節(jié)點Java學(xué)院整理7. msxml3.dll 錯誤 800c0019 系統(tǒng)錯誤:-2146697191解決方法8. jsp EL表達(dá)式詳解9. 解析原生JS getComputedStyle10. jsp cookie+session實現(xiàn)簡易自動登錄
