本文实例为大家分享了vue滚动插件better-scroll的具体代码,供大家参考,具体内容如下
1. 概述
1.1 说明
better-scroll是一款重点解决移动端(已支持PC)各种滚动场景需求的插件。例如淘宝聚划算中的类型选择(女装/家纺/生鲜美食等),没有滚动条显示却实现了滚动功能。
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提供了一个类,实例化的第一个参数是一个原生的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 结果展示
可左右滑动出所需要展示的列表集合
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
更新日志
2024年11月20日
2024年11月20日
- 柏菲·珞叔作品集《金色大厅2》限量开盘母带ORMCD[低速原抓WAV+CUE]
- Gareth.T《sad songs(Explicit)》[320K/MP3][29.03MB]
- Gareth.T《sad songs(Explicit)》[FLAC/分轨][152.85MB]
- 证声音乐图书馆《海风摇曳·盛夏爵士曲》[320K/MP3][63.06MB]
- 龚玥《金装龚玥HQCD》头版限量[WAV分轨]
- 李小春《吻别》萨克斯演奏经典[原抓WAV+CUE]
- 齐秦《辉煌30年24K珍藏版》2CD[WAV+CUE]
- 证声音乐图书馆《海风摇曳·盛夏爵士曲》[FLAC/分轨][321.47MB]
- 群星 《世界经典汽车音乐》 [WAV分轨][1G]
- 冷漠.2011 《冷漠的爱DSD》[WAV+CUE][1.2G]
- 陈明《流金岁月精逊【中唱】【WAV+CUE】
- 群星《Jazz-Ladies1-2爵士女伶1-2》HQCD/2CD[原抓WAV+CUE]
- 群星《美女私房歌》(黑胶)[WAV分轨]
- 郑源.2009《试音天碟》24BIT-96KHZ[WAV+CUE][1.2G]
- 飞利浦试音碟 《环球群星监听录》SACD香港版[WAV+CUE][1.1G]