您好,登錄后才能下訂單哦!
本篇內容介紹了“vue開發移動端使用better-scroll時click事件失效怎么辦”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
在引入better-scroll的組件中使用@click事件的時候,點擊事件失效,v-on:click、v-bind:click、@click.native都不行,試了一下@touchstart是卻是可以的,發現better-scroll的配置中沒有設置click:true,設置過之后click事件成功。
后來在使用vuex的時候一直報
[vuex] unknown mutation type: changeCity
才發現在store文件中將mutations寫在了state里面,被自己蠢哭了。。。
正確寫法如下:
相信做一些移動端項目,很多都用了better-scroll這個滾動插件,它能讓我們頁面的滾動變得不那么僵硬,同時也能讓我們實現一些錨點等功能更簡單
注:這個插件只有當你要滾動的內容高度大于你的父盒子的高度才行
npm i better-scroll --save
接著我們封裝一個Better組件,這樣在全局都能復用
<template> <div class="wrapper" ref="wrapper" :> <slot></slot> </div> </template> <script> import BScroll from 'better-scroll' export default { data() { return { allHeight:'' } }, props:{ handleToScroll:{ type:Function, default:function(){} }, handleToTouchEnd:{ type:Function, default:function(){} } }, methods: { handleToScrolltop(y){ this.scroll.scrollTo(0,y) } }, mounted() { var scroll = new BScroll(this.$refs.wrapper,{ tap:true, probeType:1 }) this.scroll = scroll scroll.on('scroll',(pos)=>{ this.handleToScroll(pos) }) scroll.on('touchEnd',(pos)=>{ this.handleToTouchEnd(pos) }) let dangqian = this.$refs.wrapper.offsetTop let zongaodu = document.documentElement.clientHeight let all = zongaodu-dangqian this.allHeight = all +"px" }, } </script> <style> </style>
動態綁定allHeight是為了讓父盒子的高度永遠為它到頁面最底部的高度,通過計算出來,這樣更有利于實現
同時封裝兩個方法,一個scroll是下拉刷新方法,touchEnd則是下拉刷新之后觸發的函數,也有很多其他的方法,例如上拉加載更多等等,可以去官網文檔中查看
接下來全局注冊這個組件,在main.js中
import Scroller from './components/content/Scroller' Vue.component('Scroller',Scroller)
在其他組件使用
比如我們想讓ul標簽里面的內容有滾動效果,就可以這樣寫
<Scroller> <ul> </ul> </Scroller>
想用封裝的方法,通過props通信即可
<Scroller :handleToScroll="handleToScroll" :handleToTouchEnd="handleToTouchEnd">
這樣頁面就有這個滾動效果了,但是要注意,它會覆蓋我們很多的原生方法,但是他對應的也有解決方法,用它內部的屬性,我舉個例子,就比如頁面的錨點跳轉
我在封裝的組件里寫了一個方法,就是讓y軸隨著移動
methods: { handleToScrolltop(y){ this.scroll.scrollTo(0,y) } },
在要使用的頁面通過調用這個方法
handleToScrolltop(),括號里面放上對應的offsetTop即可
“vue開發移動端使用better-scroll時click事件失效怎么辦”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。