小編給大家分享一下Vue實現監聽組件原生事件的方法,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討方法吧!
在首頁開發中,右下角有一個返回頂部的小箭頭,將它單獨封裝成一個BackTop組件,但是它何時出現需要依賴于首頁的滑動,即另外一個Scroll組件。如果直接在BackTop組件里面監聽,則需要通過this.$emit將事件發射到Home組件中,又在Home中監聽自定義事件,比較復雜。因此,我們直接在Home中對BackTop組件進行監聽,使用 .native
官網對于native的解釋為:
.native:監聽組件根元素的原生事件
代碼如下:
在Home.vue中對back-top組件進行點擊事件監聽:


this.$refs.scroll 得到的是 Scroll 組件,this.$refs.scroll.scroll 得到的是Scroll組件中 data 中定義的 scroll屬性,

better-scroll中有個方法是 scrollTo,

這里順便講解一下 ref 屬性的使用:
ref 被用來給DOM元素或子組件注冊引用信息。引用信息將會注冊在父組件的 $refs對象上。$refs 是所有注冊過的ref的一個集合,
如果在普通的 DOM 元素上使用,引用指向的就是 DOM 元素;如果用在子組件上,引用就指向組件實例。
1.在普通的dom結構中,在元素上添加ref屬性,this.$refs.ref獲取的是具有這個ref屬性的dom節點
2.在vue組件中,this.$refs.ref獲取的是組件的實例,組件中的data可以直接this.$refs.ref.key獲取數據
看完了這篇文章,相信你對Vue實現監聽組件原生事件的方法有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。