Vue table组件动态设置高度,列设置fixed导致的错行问题,滚动条利用鼠标横向滚动

Vue table组件动态设置高度

监听浏览器窗口变化,动态计算表格高度
data部分

data() {
    return {
      tableHeight: 700
    }
  }

mounted部分

mounted() {
   // 监听浏览器窗口变化,动态计算表格高度,
   // 225是表格外其它布局占的高度,这个数值根据自己实际情况修改
   window.addEventListener('resize', () => {
     this.tableHeight = window.innerHeight - 225
   })
 }

使用

 <el-table
        :height="tableHeight"
      >
      </el-table>

列设置Fixed解决错行问题

问题描述:日期列设置了fixed之后,发生了错行问题,但是用鼠标调整窗口大小之后会恢复正常
在这里插入图片描述
解决方案:
table标签设置ref属性

<el-table
        ref="table"
      >
      </el-table>

钩子函数updated

 updated() {
    this.$nextTick(() => {
      this.$refs.table.doLayout()
    })
  }

效果:问题完美解决
在这里插入图片描述

滚动条利用鼠标横向滚动

鼠标向下滚动时,表格向右滚动
在这里插入图片描述使用

<el-table
        ref="table"
      >
      </el-table>

data部分

data(){
return {
     domObj:null
}
}

钩子函数mouted

 mounted() {
    
    this.$refs.table.bodyWrapper.id = 'scrollBar'
    this.scrollFunction(this.domObj, 'scrollBar')
  }

methods

methods:{

scrollFunction(obj, id) {
      obj = document.getElementById(id)
      if (obj.attachEvent) {
        obj.attachEvent('onmousewheel', this.mouseScroll(obj))
      } else if (obj.addEventListener) {
        obj.addEventListener('DOMMouseScroll', this.mouseScroll(obj), false)
      }
      obj.onmousewheel = obj.onmousewheel = this.mouseScroll(obj)
    },
    mouseScroll(obj) {
      return function() {
        let e = window.event || document.all ? window.event : arguments[0] ? arguments[0] : event
        let detail, moveForwardStep, moveBackStep
        let step = 0
        if (e.wheelDelta) { // google 下滑负数: -120
          detail = e.wheelDelta
          moveForwardStep = -1
          moveBackStep = 1
        } else if (e.detail) { // firefox 下滑正数:3
          detail = event.detail
          moveForwardStep = 1
          moveBackStep = -1
        }
        step = detail > 0 ? moveForwardStep * 100 : moveBackStep * 100
        // e.preventDefault()
        let left = obj.querySelector('table').clientWidth - obj.clientWidth
        // 这里是为了向右滚动后再向下滚动,向左滚动后再向上滚动,如果不需要,只需要写e.preventDefault()
        if (moveForwardStep === -1) {//google
          if (detail > 0) {//向上
            if (obj.scrollLeft > 0) {
              e.preventDefault()
            } else {
              return true
            }
          } else {
            if (obj.scrollLeft < left) {
              e.preventDefault()
            } else {
              return true
            }
          }
        } else {//firefox
          if (detail > 0) {//向下
            if (obj.scrollLeft < left) {
              e.preventDefault()
            } else {
              return true
            }
          } else {
            if (obj.scrollLeft > 0) {
              e.preventDefault()
            } else {
              return true
            }
          }
        }
        obj.scrollLeft = obj.scrollLeft + step
      }
    }
}
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值