【JS】计算任意字符串的像素宽度(px)

文章目录

代码实现

函数封装:

ts 复制代码
export function getStringWidthDOM(
  str: string,
  {
    fontSize = '16px',
    fontFamily = 'Segoe UI Emoji, Segoe UI Symbol',
    fontWeight = 'normal',
    fontStyle = 'normal',
  }: { fontSize?: string; fontFamily?: string; fontWeight?: string | number; fontStyle?: string },
): number {
  const span = document.createElement('span');
  span.style.cssText = `
      position: absolute;
      visibility: hidden;
      white-space: nowrap;
      font-size: ${fontSize};
      font-family: ${fontFamily};
      font-weight: ${fontWeight};
      font-style: ${fontStyle};
    `;
  span.textContent = str;
  document.body.appendChild(span);
  const width = span.offsetWidth;
  document.body.removeChild(span);
  return width;
}

使用案例:

ts 复制代码
const width: number = getStringWidthDOM('Hello, TS!', {
  fontSize: '14px',
  fontWeight: 'bold'
});
相关推荐
噢,我明白了1 天前
JavaScript 中处理时间格式的核心方式
前端·javascript
C_心欲无痕1 天前
vue3 - 类与样式的绑定
javascript·vue.js·vue3
南山安1 天前
Tailwind CSS:顺风CSS
javascript·css·react.js
栀秋6661 天前
防抖 vs 节流:从百度搜索到京东电商,看前端性能优化的“节奏哲学”
前端·javascript
有意义1 天前
深入防抖与节流:从闭包原理到性能优化实战
前端·javascript·面试
2503_928411561 天前
12.26 小程序问题和解决
前端·javascript·微信小程序·小程序
over6971 天前
防抖与节流:前端性能优化的“双子星”,让你的网页丝滑如德芙!
前端·javascript·面试
red润1 天前
手把手封装Iframe父子单向双向通讯功能
前端·javascript·vue.js
gustt1 天前
JavaScript 闭包实战:手写防抖与节流函数,优化高频事件性能
前端·javascript·面试