2020-11-17 better-scroll vue实现手机端浏览表格,表头和首列固定显示

前提准备

安装: npm i better-scroll --S

接下来直接放代码:

<template>

  <div id="div_page">

    <div id="left"

         ref="left">

      <div class="left_box">

        <div class="title_box1"

             :style="{top:top+'px'}">

          <div class="title_child1">0头部</div>

          <div class="title_child1">1头部</div>

          <div class="title_child1">2头部</div>

          <div class="title_child1">3头部</div>

          <div class="title_child1">4头部</div>

          <div class="title_child1">5头部</div>

          <div class="title_child1">6头部</div>

          <div class="title_child1">7头部</div>

          <div class="title_child1">8头部</div>

          <div class="title_child1">9头部</div>

        </div>

        <div class="left_data">

          <div v-for="(item,index) in 150"

               :key="index"

               class="title_box">

            <div class="title_child1">{{index}}右侧0</div>

            <div class="title_child1">内容1</div>

            <div class="title_child1">内容2</div>

            <div class="title_child1">内容3</div>

            <div class="title_child1">内容4</div>

            <div class="title_child1">内容5</div>

            <div class="title_child1">内容6</div>

            <div class="title_child1">内容7</div>

            <div class="title_child1">内容8</div>

            <div class="title_child1">内容9</div>

          </div>

        </div>

      </div>

    </div>

    <div id="right"

         ref="right">

      <div>

        <div class="title_child2">

          头部

        </div>

        <div class="right_data">

          <div v-for="(item,index) in 150"

               :key="index">

            <div class="title_child">

              右侧{{index}}

            </div>

          </div>

        </div>

      </div>

    </div>

  </div>

</template>

<script>

import BScroll from 'better-scroll'   //1.引入滚动插件

let BSleft = null

let right_scroll = null

let left_scroll = null

export default {

  data () {

    return {

      flag: true,

      top: ""

    }

  },

  mounted () {

    //创建滚动插件

    //滚动效果只能作用于this.$refs.left 元素的第一个子盒子,所以要根据需求将布局放在同一个div(子盒子)里面。

    //并且在设置子盒子的宽高时要根据滚动的要求设置。即在父盒子设置固定宽高后,子盒子要超过父盒子高度。

    BSleft = new BScroll(this.$refs.left, {

      probeType: 3,

      scrollY: true,  //Y轴滚动

      scrollX: true,  //X轴滚动

      click: true,     //允许点击事件

      bounce: false,    //回弹效果

      momentumLimitDistance: 5

    })

    left_scroll = this.$refs.left

    right_scroll = this.$refs.right

    //滚动开始的事件

    BSleft.on('scrollStart', (pos) => {

      console.log(pos);

    })

    //滚动的事件

    BSleft.on('scroll', (pos) => {

      right_scroll.scrollTop = -pos.y

      this.top = -pos.y

      console.log(pos);

    })

    //滚动结束后的事件

    BSleft.on('scrollEnd', (pos) => {

      console.log(pos);

    })

  },

  methods: {

  }

}

</script>

<style lang="less" scoped>

#div_page {

  width: 100vw;

  height: 100vh;

  display: flex;

  justify-self: left;

}

#right {

  width: 20%;

  height: 100vh;

  overflow: hidden;

  box-sizing: border-box;

}

.title_child2 {

  position: fixed;

  top: 0px;

  right: 0px;

  width: 20%;

  height: 20px;

  line-height: 20px;

  background: rgb(136, 136, 201);

  text-align: center;

  box-sizing: border-box;

  border-left: 1px solid #a7a5a5;

  border-bottom: 1px solid #a7a5a5;

}

.right_data {

  margin-top: 20px;

}

.title_child {

  width: 100%;

  height: 20px;

  line-height: 20px;

  text-align: center;

  box-sizing: border-box;

  border-left: 1px solid #a7a5a5;

  border-bottom: 1px solid #a7a5a5;

}

.title_child1 {

  width: 10%;

  height: 20px;

  line-height: 20px;

  text-align: center;

  box-sizing: border-box;

  border-left: 1px solid #a7a5a5;

  border-bottom: 1px solid #a7a5a5;

}

#left {

  background: #b2e4d7;

  width: 80%;

  height: 100vh;

  overflow: hidden;

  box-sizing: border-box;

  border: 1px solid #a7a5a5;

}

.left_box {

  width: 1000px;

  height: auto;

}

.left_data {

  padding-top: 20px;

}

.title_box {

  width: 1000px;

  height: 20px;

  line-height: 20px;

  display: flex;

  justify-self: left;

}

.title_box1 {

  position: fixed;

  left: 0;

  width: 1000px;

  height: 20px;

  line-height: 20px;

  background: rgb(136, 136, 201);

  display: flex;

  justify-self: left;

}

</style>

安装完better-scroll插件后,此代码在vue项目中可以直接运行,可以进行学习测试(变量取名比较随意)。

下面说一下,使用better-scroll的注意点:

1.创建better-scroll之前,要保证dom是已经渲染完成的,不然会造成作用上但是不能滚动的bug(在项目中一般是异步请求数据渲染,因此在注意在加载完成后再创建组件。)。

2.父盒子的宽高要固定,超出要隐藏(overflow:hidden),子盒子的宽高至少有一个是设置的超过父盒子宽度或者由内容撑开并超过父盒子。

这个demo只是简单的实现,因为优化不好并未采用,只是给大家提供一个思路。大家还得动脑子去优化啊,另外,组件中的其他参数还是需要大家自己摸索了。

将组件中的参数和方法放下面供大家参考:

Options 参数

startX: 0 开始的X轴位置

startY: 0 开始的Y轴位置

scrollY: true 滚动方向为 Y 轴

scrollX: true 滚动方向为 X 轴

click: true 是否派发click事件,通常判断浏览器派发的click还是betterscroll派发的click,可以用_constructed,若是bs派发的则为true

directionLockThreshold: 5

momentum: true 当快速滑动时是否开启滑动惯性

bounce: true 是否启用回弹动画效果

selectedIndex: 0 wheel 为 true 时有效,表示被选中的 wheel 索引

rotate: 25 wheel 为 true 时有效,表示被选中的 wheel 每一层的旋转角度

wheel: false 该属性是给 picker 组件使用的,普通的列表滚动不需要配置

snap: false 该属性是给 slider 组件使用的,普通的列表滚动不需要配置

snapLoop: false 是否可以无缝循环轮播

snapThreshold: 0.1 用手指滑动时页面可切换的阈值,大于这个阈值可以滑动的下一页

snapSpeed: 400, 轮播图切换的动画时间

swipeTime: 2500 swipe 持续时间

bounceTime: 700 弹力动画持续的毫秒数

adjustTime: 400 wheel 为 true 有用,调整停留位置的时间

swipeBounceTime: 1200 swipe 回弹 时间

deceleration: 0.001 滚动动量减速越大越快,建议不大于0.01

momentumLimitTime: 300 符合惯性拖动的最大时间

momentumLimitDistance: 15 符合惯性拖动的最小拖动距离

resizePolling: 60 重新调整窗口大小时,重新计算better-scroll的时间间隔

preventDefault: true 是否阻止默认事件

preventDefaultException: { tagName: /^(INPUT|TEXTAREA|BUTTON|SELECT)$/ } 阻止默认事件

HWCompositing: true 是否启用硬件加速

useTransition: true 是否使用CSS3的Transition属性

useTransform: true 是否使用CSS3的Transform属性

probeType: 1 滚动的时候会派发scroll事件,会截流。2滚动的时候实时派发scroll事件,不会截流。 3除了实时派发scroll事件,在swipe的情况下仍然能实时派发scroll事件

Events 事件

beforeScrollStart - 滚动开始之前触发

scrollStart - 滚动开始时触发

scroll - 滚动时触发

scrollCancel - 取消滚动时触发

scrollEnd - 滚动结束时触发

touchend - 手指移开屏幕时触发

flick - 触发了 fastclick 时的回调函数

refresh - 当 better-scroll 刷新时触发

destroy - 销毁 better-scroll 实例时触发

函数列表

scrollTo(x, y, time, easing)

滚动到某个位置,x,y 代表坐标,time 表示动画时间,easing 表示缓动函数

scroll.scrollTo(0, 500)

scrollToElement(el, time, offsetX, offsetY, easing)

滚动到某个元素,el(必填)表示 dom 元素,time 表示动画时间,offsetX 和 offsetY 表示坐标偏移量,easing 表示缓动函数

refresh()

强制 scroll 重新计算,当 better-scroll 中的元素发生变化的时候调用此方法

getCurrentPage()

snap 为 true 时,获取滚动的当前页,返回的对象结构为 {x, y, pageX, pageY},其中 x,y 代表滚动横向和纵向的位置;pageX,pageY 表示横向和纵向的页面索引。用法如:getCurrentPage().pageX

goToPage(x, y, time, easing)

snap 为 true,滚动到对应的页面,x 表示横向页面索引,y 表示纵向页面索引, time 表示动画,easing 表示缓动函数(可省略不写)

enable()启用 better-scroll,默认开启

disable()  禁用 better-scroll

destroy() 销毁 better-scroll,解绑事件


链接:https://www.jianshu.com/p/035080954ee9

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,547评论 6 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,399评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,428评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,599评论 1 274
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,612评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,577评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,941评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,603评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,852评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,605评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,693评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,375评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,955评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,936评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,172评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,970评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,414评论 2 342