I mentioned a simple CSS trick to generate full-width figures in 2021. I was thinking the other day if I could make certainly elements automatic, so I do not need to manually specify them to be full-width. Finally, I wrote some JS code to deal with three types of elements automatically:
-
Code blocks (
<pre><code>).If the
scrollWidthis greater thanoffsetWidth, it means the code block has a horizontal scrollbar, and we may want to make it full-width. -
Tables (
<table>).If its
offsetWidthis greater than its parent’soffsetWidth, it is too wide. -
Table of contents (an element that has the ID
TableOfContents, e.g.,<nav id="TableOfContents">).If any TOC item has multiple rectangles on the layout (
getClientRects().length > 1), it means the item is wrapped, and the TOC may benefit from more space.
The JS code will add a class name fullwidth to elements that need more space.
Users can define CSS rules for this class, e.g.,
.fullwidth {
width: 100vw;
margin-left: calc(50% - 50vw);
}
On my website, I do not really use the full screen width, but only the body
width. It’s up to you how wide you want your .fullwidth elements to be. You
can load the JS from the jsdelivr CDN:
<script src="https://cdn.jsdelivr.net/npm/@xiee/utils/js/fullwidth.min.js" defer></script>
The above code block is also an example of an automatic full-width element. If you view it on a large screen such as your computer screen, it should take the full body width.
Donate
As a freelancer (currently working as a contractor) and a dad of three kids, I truly appreciate your donation to support my writing and open-source software development! Your contribution helps me cope with financial uncertainty better, so I can spend more time on producing high-quality content and software. You can make a donation through methods below.
-
Venmo:
@yihui_xie, or Zelle:xie@yihui.name -
Paypal
-
If you have a Paypal account, you can follow the link https://paypal.me/YihuiXie or find me on Paypal via my email
xie@yihui.name. Please choose the payment type as “Family and Friends” (instead of “Goods and Services”) to avoid extra fees. -
If you don’t have Paypal, you may donate through this link via your debit or credit card. Paypal will charge a fee on my side.
-
-
Other ways:
WeChat Pay (微信支付:谢益辉) Alipay (支付宝:谢益辉) 

When sending money, please be sure to add a note “gift” or “donation” if possible, so it won’t be treated as my taxable income but a genuine gift. Needless to say, donation is completely voluntary and I appreciate any amount you can give.
Please feel free to email me if you prefer a different way to give. Thank you very much!
I’ll give back a significant portion of the donations to the open-source community and charities. For the record, I received about $30,000 in total (before tax) in 2024-25, and gave back about $15,000 (after tax).