【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'
});
相关推荐
zithern_juejin3 分钟前
Date/RegExp/Error/ArrayBuffer
javascript
燐妤25 分钟前
前端HTML编程5:JavaScript完全指南
前端·javascript·html
八月欢喜29 分钟前
【Facebook】 实时消息监控难点解析
javascript·python·facebook
zithern_juejin1 小时前
Map/Set/WeakMap/WeakSet
javascript
砚底藏山河2 小时前
python、JavaScript 、JAVA,定制化数据服务,助力业务高效落地
java·javascript·python
11_x2 小时前
JS 底层:乖宝宝引擎和乖宝宝声明
javascript
flex罗小黑2 小时前
前端手机号脱敏的 4 个层级,你在第几层?
javascript
孙6903422 小时前
electron播放本地任意格式的视频
前端·javascript
openKaka_2 小时前
reconcileChildren 深入:React 如何根据 ReactElement 构建子 Fiber
前端·javascript·react.js
zithern_juejin3 小时前
typeof、instanceof与Object.prototype.toString()
javascript