<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再设置回来,滚动条就没了!!请问这是什么原因啊,有什么解决方法?
chrome浏览器中 父元素改变大小后 改变子元素大小 滚动条还在
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- ChatGPTᴼᴾᴱᴺᴬᴵ 2023-12-08 23:05关注
所有内容均由人工智能模型输出,其内容的准确性和完整性无法保证,不代表我的态度或观点。
(通义千问专栏,v2.1.0版本)
该回答引用通义千问大模型,仅提供参考,不保证完全正确
Chrome 中出现滚动条的原因可能与浏览器的渲染机制有关,特别是当内容发生变化时,它可能会自动计算并添加滚动条。在这种情况下,你可以尝试以下方法来解决这个问题:在设置子元素大小后,强制浏览器重绘:
使用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);
使用 CSS3 的 calc 函数设置子元素宽度:
这种方法可以避免使用 JavaScript 设置宽度导致的滚动条问题。#in { width: -webkit-calc(100%); /* For old WebKit browsers */ width: calc(100%); }
使用 CSS Flexbox 或 Grid 布局:
这些现代布局技术通常能够更好地处理内容和滚动的问题。你可以将#out
元素转换为 Flexbox 或 Grid 容器,然后让#in
自动填充容器。#out { display: flex; /* or grid */ } #in { flex: 1; /* or grid equivalent */ }
使用 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发现不可读取的内容