时间:2021-05-26
本文实例为大家分享了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 结果展示
可左右滑动出所需要展示的列表集合
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
最近使用vue学习开发移动端的项目,使用了bette-scroll插件做滚动。在引入better-scroll的组件中使用@click事件的时候,点击事件失效,
better-scroll是什么better-scroll是一款重点解决移动端(已支持PC)各种滚动场景需求的插件。它的核心是借鉴的iscroll的实现,它的A
根据vue-music视频中slider组建的使用,当安装新版本的better-scroll,轮播组件,不能正常轮播这是因为,better-scroll发布新版
本文实例为大家分享了vue基于better-scroll实现左右联动滑动页面,供大家参考,具体内容如下界面如下:vue模板{{good.name}}{{good
一、首先安装安装npminstallbetter-scroll--save二、并在组件中引用importBScrollfrom‘better-scroll'te