本文實例為大家分享了vue滾動插件better-scroll的具體代碼,供大家參考,具體內容如下
網(wǎng)站建設公司,為您提供網(wǎng)站建設,網(wǎng)站制作,網(wǎng)頁設計及定制網(wǎng)站建設服務,專注于企業(yè)網(wǎng)站建設,高端網(wǎng)頁制作,對門窗定制等多個行業(yè)擁有豐富的網(wǎng)站建設經(jīng)驗的網(wǎng)站建設公司。專業(yè)網(wǎng)站設計,網(wǎng)站優(yōu)化推廣哪家好,專業(yè)網(wǎng)站推廣優(yōu)化,H5建站,響應式網(wǎng)站。
1. 概述
1.1 說明
better-scroll是一款重點解決移動端(已支持PC)各種滾動場景需求的插件。例如淘寶聚劃算中的類型選擇(女裝/家紡/生鮮美食等),沒有滾動條顯示卻實現(xiàn)了滾動功能。
1.2 better-scroll安裝
npm install better-scroll --save 安裝至項目中
1.3 better-scroll使用
better-scroll常見應用場景(列表滾動)的html結構:
<div class="wrapper"> <ul class="content"> <li>...</li> <li>...</li> ... </ul> <!-- 這里可以放一些其它的 DOM,但不會影響滾動 --> </div>
備注:better-scroll是作用在外層wrapper容器上的,滾動的部分是content元素。并且better-scroll只處理容器(wrapper)的第一個子元素(content)的滾動,其他的元素都會被忽略。
better-scroll初始化代碼:
better-scroll提供了一個類,實例化的第一個參數(shù)是一個原生的DOM對象,如果不是傳遞的對象,而是傳遞的字符串(類名或者id),better-scroll內部會嘗試調用querySelector去獲取這個DOM對象。
<->直接傳遞DOM對象
import BScroll from 'better-scroll'
let wrapper = document.querySelector('.wrapper')
let scroll = new BScroll(wrapper)<二>傳遞字符串,使better-scroll內部去獲取DOM對象
import BScroll from 'better-scroll'
let scroll = new BScroll('.wrapper')2. 代碼
2.1 代碼示例
2.1 子組件scrollChild(橫向滾動組件)
<template>
<div class='move-tabs'>
<div class='tabs-wrapper' ref='tabsWrapper'>
<ul ref='tab'>
<li v-for='(item, index) in tabs' :key='index'>
<div class='tab-item'>
<div class='expand-block'>
{{item.name||'無'}}
</div>
</div>
</li>
</ul>
</div>
</div>
</template>
<script>
import BScroll from 'better-scroll'
export default {
props: {
data: Array,
},
data() {
return {
tabs: [],
mX: 0,
tabWidth: 300,
}
},
mounted() {
this.$nextTick(() => {
console.log(this.data)
this.tabs = this.data
this._initMenu()
})
},
methods: {
_initMenu() {
const tabsWidth = this.tabWidth
const width = this.tabs.length * tabsWidth
this.$refs.tab.style.width = `${width}px`
this.$nextTick(() => {
if (!this.scroll) {
this.scroll = new BScroll(this.$refs.tabsWrapper, {
scrollX: true,
eventPassthrough: 'vertical',
})
} else {
this.scroll.refresh()
}
})
},
},
}
</script>
<style scoped>
.move-tabs {
position: relative;
top: 0;
bottom: 0;
width: 100%;
}
.tabs-wrapper {
height: 120px;
width: 100%;
box-sizing: border-box;
overflow: hidden;
white-space: nowrap;
}
.tab-item {
float: left;
width: 280px;
height: 120px;
padding: 10px;
margin-right: 20px;
background: #f5f5;
box-shadow: 0 0 4px 0 rgba(0, 0, 0, 0.1);
border-radius: 4px;
}
.expand-block {
font-size: 30px;
font-weight: bold;
color: #333333;
}
</style>2.1 父組件scrollParent(調用子組件)
<template>
<div>
<child-scroll :data='scrollList' />
</div>
</template>
<script>
import ChildScroll from '../components/scrollChild'
export default {
name: "scrollParent.vue",
components: {
ChildScroll,
},
data(){
return {
scrollList:[
{name:'北京'},
{name:'上海'},
{name:'杭州'},
{name:'廣州'},
{name:'鄭州'},
{name:'深圳'},
{name:'合肥'},
{name:'徐州'},
{name:'西安'},
{name:'石家莊'},
{name:'呼和浩特'},
{name:'蘭州'},
{name:'包頭'},
{name:'重慶'},
]
}
},
}
</script>
<style scoped>
</style>2.2 結果展示
可左右滑動出所需要展示的列表集合

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。
文章標題:vue滾動插件better-scroll使用詳解
當前地址:http://chinadenli.net/article44/ipjeee.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供微信小程序、Google、搜索引擎優(yōu)化、網(wǎng)站策劃、建站公司、網(wǎng)站排名
聲明:本網(wǎng)站發(fā)布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)