Skip to content

搞英语 → 看世界

翻译英文优质信息和名人推特

Menu
  • 首页
  • 作者列表
  • 独立博客
  • 专业媒体
  • 名人推特
  • 邮件列表
  • 关于本站
Menu

通过 JavaScript 和 CSS 自动将 HTML 元素设置为全角

Posted on 2023-09-15

标志.png

我提到了一个简单的 CSS 技巧,可以在 2021 年生成全角图形。前几天我在想,是否可以使某些元素自动生成,这样我就不需要手动将它们指定为全角。最后,我编写了一些 JS 代码来自动处理三种类型的元素:

  1. 代码块( <pre><code> )。

    如果scrollWidth大于offsetWidth ,则意味着代码块有一个水平滚动条,我们可能希望将其设置为全角。

  2. 表( <table> )。

    如果其offsetWidth大于其父级的offsetWidth ,则它太宽。

  3. 目录(具有 ID TableOfContents元素,例如<nav id="TableOfContents"> )。

    如果任何 TOC 项目在布局上有多个矩形 ( getClientRects().length > 1 ),则意味着该项目已换行,并且 TOC 可能会受益于更多空间。

JS 代码将为需要更多空间的元素添加fullwidth角类名。用户可以为该类定义 CSS 规则,例如:

 .fullwidth { width: 100vw; margin-left: calc(50% - 50vw); }

在我的网站上,我并没有真正使用全屏宽度,而仅使用主体宽度。这取决于您想要.fullwidth元素的宽度。您可以从 jsdelivr CDN 加载 JS:

 <script src="https://cdn.jsdelivr.net/npm/@xiee/utils/js/fullwidth.min.js" defer></script>

上面的代码块也是自动全角元素的示例。如果您在大屏幕(例如计算机屏幕)上查看它,它应该占据整个正文的宽度。

原文: https://yihui.org/en/2023/09/auto-fullwidth/

本站文章系自动翻译,站长会周期检查,如果有不当内容,请点此留言,非常感谢。
  • Abhinav
  • Abigail Pain
  • Adam Fortuna
  • Alberto Gallego
  • Alex Wlchan
  • Answer.AI
  • Arne Bahlo
  • Ben Carlson
  • Ben Kuhn
  • Bert Hubert
  • Bits about Money
  • Brian Krebs
  • ByteByteGo
  • Chip Huyen
  • Chips and Cheese
  • Christopher Butler
  • Colin Percival
  • Cool Infographics
  • Dan Sinker
  • David Walsh
  • Dmitry Dolzhenko
  • Dustin Curtis
  • Elad Gil
  • Ellie Huxtable
  • Ethan Marcotte
  • Exponential View
  • FAIL Blog
  • Founder Weekly
  • Geoffrey Huntley
  • Geoffrey Litt
  • Greg Mankiw
  • Henrique Dias
  • Hypercritical
  • IEEE Spectrum
  • Investment Talk
  • Jaz
  • Jeff Geerling
  • Jonas Hietala
  • Josh Comeau
  • Lenny Rachitsky
  • Liz Danzico
  • Lou Plummer
  • Luke Wroblewski
  • Matt Baer
  • Matt Stoller
  • Matthias Endler
  • Mert Bulan
  • Mostly metrics
  • News Letter
  • NextDraft
  • Non_Interactive
  • Not Boring
  • One Useful Thing
  • Phil Eaton
  • Product Market Fit
  • Readwise
  • ReedyBear
  • Robert Heaton
  • Ruben Schade
  • Sage Economics
  • Sam Altman
  • Sam Rose
  • selfh.st
  • Shtetl-Optimized
  • Simon schreibt
  • Slashdot
  • Small Good Things
  • Taylor Troesh
  • Telegram Blog
  • The Macro Compass
  • The Pomp Letter
  • thesephist
  • Thinking Deep & Wide
  • Tim Kellogg
  • Understanding AI
  • 英文媒体
  • 英文推特
  • 英文独立博客
©2025 搞英语 → 看世界 | Design: Newspaperly WordPress Theme