vue设置scrollLeft 一直为0的原因

问题描述

<div class="icontent" ref="icontent" >
    <div class="box" ref="cbox" >
      <img />
    </div>
</div>
  1. img 是position: absolute;绝对定位
  2. icontent,cbox是 position: relative
  3. 多个img横向平铺撑开cbox出现滚动条
  4. 鼠标拖动滚动条可以显示隐藏部分内容

新需求鼠标滚轮滚动控制滚动条,控制显示的内容; 想当然获取cbox 设置scrollleft;但是一直为0;
原因是出现滚动条的不是cbox 而是他的上层容器;
所以scrollLeft不能正确设置值可能就是没有找到出现滚动条的容器
解决步骤:

  1. 找到出现滚动条的容器
window.addEventListener('scroll', this.windowScroll, true);
windowScroll(){   
   console.log( document.querySelector(".box").parentElement.parentElement.parentElement.scrollLeft)    // 查看打印的值是否有变化 如果有 则说明滚滚动条在这个标签中
},

//scrollLeft=0 最左边;scrollWidth-clientWidth 最右边
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值