1. 面向开发者的 Web 技术
  2. Web API
  3. Element
  4. Element:scrollWidth 属性

此页面由社区从英文翻译而来。了解更多并加入 MDN Web Docs 社区。

View in English Always switch to English

Element:scrollWidth 属性

基线 广泛可用

自 2015年7月 起,此特性已在主流浏览器中得到支持,可在大多数设备和浏览器版本中正常使用。

Element.scrollWidth 只读属性是元素内容宽度的一种度量,包括由于溢出而在屏幕上不可见的内容。

scrollWidth 值等于元素在不使用水平滚动条的情况下适合视口中的所有内容所需的最小宽度。宽度的测量方式与 clientWidth 相同:它包含元素的内边距,但不包括边框、外边距或垂直滚动条(如果存在)。它还可以包括伪元素的宽度,例如 ::before::after。如果元素的内容可以在不需要水平滚动条的情况下容纳,则其 scrollWidth 等于 clientWidth

备注:该属性会将值取整成整数。如果你需要小数值,请使用 Element.getBoundingClientRect()

一个整数。

示例

检测内容溢出

在此示例中,我们使用 scrollWidth 属性来检查元素的内容是否溢出其边界。我们有两个 div 元素,第一个的宽度为 100px,而第二个的宽度不固定。它们的内容完全相同,我们会显示一条消息,说明内容是否溢出了各自的容器。

HTML

html
<div id="div1">这是一条很长很长的内容</div>
<button id="button1">溢出检查</button>
<pre id="log1"></pre>
<div id="div2">这是一条很长很长的内容</div>
<button id="button2">溢出检查</button>
<pre id="log2"></pre>

CSS

css
div {
 padding: 0.15em;
 overflow: hidden;
 white-space: nowrap;
 text-overflow: ellipsis;
}
button {
 margin: 0.15em 0 0.5em 0;
}
pre {
 margin: 0.5em 0;
}
#div1 {
 width: 100px;
}
#log1 {
 margin-bottom: 2em;
}

JavaScript

js
const button1 = document.getElementById("button1");
const button2 = document.getElementById("button2");
const div1 = document.getElementById("div1");
const div2 = document.getElementById("div2");
const log1 = document.getElementById("log1");
const log2 = document.getElementById("log2");
// 检查 scrollWidth 是否大于 clientWidth
function isOverflowing(element) {
 return element.scrollWidth > element.clientWidth;
}
function checkOverflow(element, log) {
 if (isOverflowing(element)) {
 log.innerText = `内容溢出,scrollWidth 为 ${element.scrollWidth}px`;
 } else {
 log.innerText = `没有溢出,scrollWidth 为 ${element.scrollWidth}px`;
 }
}
button1.addEventListener("click", () => {
 checkOverflow(div1, log1);
});
button2.addEventListener("click", () => {
 checkOverflow(div2, log2);
});

结果

单击按钮检查内容是否溢出容器。

规范

规范
CSSOM View Module
# dom-element-scrollwidth

浏览器兼容性

参见

帮助改进 MDN

了解如何参与贡献

此页面最后更新于 ,由 MDN 贡献者更新。

AltStyle によって変換されたページ (->オリジナル) /