h19900913y 2014-04-17 08:42 采纳率: 0%
浏览 1032

chrome浏览器中 父元素改变大小后 改变子元素大小 滚动条还在

<div id="out" style="position:relative; overflow:auto;">
<div id="in">123</div>
</div>
窗口改变大小的时候,先改变out的大小与窗口一致,再改变in的大小充满out,设置大小的方法都是jquery的outerWidth/outerHeight,在IE下没问题,但是在chrome浏览器中,out会出现滚动条;如果在调试工具中删除in的width再设置回来,滚动条就没了!!请问这是什么原因啊,有什么解决方法?

  • 写回答

1条回答 默认 最新

  • ChatGPTᴼᴾᴱᴺᴬᴵ 2023-12-08 23:05
    关注

    所有内容均由人工智能模型输出,其内容的准确性和完整性无法保证,不代表我的态度或观点。
    (通义千问专栏,v2.1.0版本)


    该回答引用通义千问大模型,仅提供参考,不保证完全正确
    Chrome 中出现滚动条的原因可能与浏览器的渲染机制有关,特别是当内容发生变化时,它可能会自动计算并添加滚动条。在这种情况下,你可以尝试以下方法来解决这个问题:

    1. 在设置子元素大小后,强制浏览器重绘
      使用 window.getComputedStyle() 获取元素的实际样式,并通过改变某个不会影响布局的属性(例如 opacity)来触发重绘。

      var out = $("#out");
      var inEl = $("#in");
      
      // 改变窗口大小后调整元素大小
      function resizeElements() {
        var winWidth = $(window).width();
        var winHeight = $(window).height();
      
        // 设置父元素大小
        out.outerWidth(winWidth);
        out.outerHeight(winHeight);
      
        // 设置子元素大小并触发重绘
        inEl.width("100%");  // 先设置一个宽度
        var computedStyle = window.getComputedStyle(inEl[0]);
        inEl.css({ opacity: computedStyle.opacity }); // 强制重绘
        inEl.width("100%");
      }
      
      // 监听窗口大小变化事件
      $(window).on("resize", resizeElements);
      
    2. 使用 CSS3 的 calc 函数设置子元素宽度
      这种方法可以避免使用 JavaScript 设置宽度导致的滚动条问题。

      #in {
        width: -webkit-calc(100%); /* For old WebKit browsers */
        width: calc(100%);
      }
      
    3. 使用 CSS Flexbox 或 Grid 布局
      这些现代布局技术通常能够更好地处理内容和滚动的问题。你可以将 #out 元素转换为 Flexbox 或 Grid 容器,然后让 #in 自动填充容器。

      #out {
        display: flex; /* or grid */
      }
      
      #in {
        flex: 1; /* or grid equivalent */
      }
      
    4. 使用 CSS3 transition 动画
      #in 元素上添加过渡动画也可以帮助避免滚动条问题。

      #in {
        transition: width 0s;
      }
      

    请注意,上述解决方案可能需要根据你的具体代码进行调整。在实际项目中,确保测试不同的浏览器和设备以获得最佳兼容性。

    评论

报告相同问题?

悬赏问题

  • ¥15 maixpy训练模型,模型训练好了以后,开发板通电会报错,不知道是什么问题
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 有没有帮写代码做实验仿真的
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥30 vmware exsi重置后登不上
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容