javascript - DOM 元素计算样式字体大小太小

标签 javascript html css font-size

我在 JavaScript 代码中使用以下两种方法获取 DOM 中 spanfont-size:

const element = document.querySelector('h2 span');
const fontSizeObj = element.computedStyleMap().get('font-size');
const fontSizeStr = window.getComputedStyle(element, null).getPropertyValue('font-size');

此代码使用两种方法获得相同的值。第一次调用 (fontSizeObj) 有效地返回以下内容:

{value: 25.600000381469727, unit: "px"}

第二次调用 (fontSizeStr) 返回以下内容:

"25.6px"

这些值是一致的;这很好。

span上没有直接的CSS样式,但是在parent h2上通过样式表有直接的样式,如下: 字体大小:5rem;

在 (Chrome) 控制台中查看 spancomputed font-size 我看到它是:

80px

此控制台值与上面返回的值有很大不同。此控制台值还对应于浏览器中文本的查看/呈现大小。

如果我将元素 font-size 的值设置为任一返回值,那么显示的文本大小显然会显着缩小。

那么,如何获取 span 中文本的实际计算字体大小?

提前致谢。

最佳答案

好的,事情是这样的……在网上搜索时,我记得在某个地方读到过,样式的更改可以相对于您从中观察状态的线程异步发生。

因此,我将这段代码混合在一起:

setTimeout(() => {
  console.log(element.computedStyleMap().get('font-size'));
}, 0);

现在我得到 font-sze预期 值为 80px

我可以用那个……

问题已解决。

关于javascript - DOM 元素计算样式字体大小太小,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59044869/

相关文章:

javascript - 使用字符串数组过滤对象数组以获取带有 '&&' 子句的结果

javascript - ExtJS在另一个 Controller 中初始化 Controller

html - 不知道如何在 ngx-select-dropdown Angular 8 中设置选项

javascript - 如何使用 javascript 从 HTML 选择选项 onchange 中发布 PHP 变量?

html - 位置固定且宽度 25% 未采用正确的宽度

javascript - 即使单个图像存在单项模式, Owl Carousel 也会自动刷新

javascript - “Cannot GET/” 尝试连接到本地主机时 :8080 in node. js

html - 强制 html 将 ""解释为 nbsp 文本节点

jquery - 添加图像时 Bootstrap Carousel 导航消失

html - Bootstrap 使用 select 作为输入附加组件