1

<div style="width : 50px"></div>

When the number of letters increases and leaves the area, Is there a way to automatically reduce the font size instead of css overflow?

1wooseok
  • 19
  • 2
  • Not sure - you might have to use javascript – skara9 Jan 11 '22 at 04:43
  • 1
    [text-justify](https://developer.mozilla.org/en-US/docs/Web/CSS/text-justify) might help. Also, welcome to StackOverflow, please review [ask] and provide a [mcve] when asking a question – admcfajn Jan 11 '22 at 04:44

1 Answers1

5

I found this question interesting, so I'll provide a simple JavaScript example in case it helps somebody.

const div = document.querySelector('div');
const span = document.querySelector('span');


createDynamicTextbox(div, span);


function createDynamicTextbox(outer, inner) {
  if (!outer.style.fontSize) outer.style.fontSize = outer.clientHeight;
  const initialSize = +outer.style.fontSize.match(/\d+/)[0];

  inner.addEventListener('input', function(e) {
    let [n, unit] = outer.style.fontSize.split(/(?<![a-z])(?=[a-z]+)/);
    n=+n;

    while (outer.offsetWidth > inner.offsetWidth) {
      n++;
      outer.style.fontSize = n+unit;
      if (n >= initialSize) return;
    }

    while (inner.offsetWidth > outer.offsetWidth) {
      n--;
      outer.style.fontSize = n+unit;
      if (n <= 0) return;
    }
  });

  inner.dispatchEvent(new InputEvent('input'));
}
div {
  width: 100px;
  overflow: hidden;
  white-space: nowrap;
}
<div style="font-size: 30px"><span contenteditable>Edit Me</span></div>
skara9
  • 4,042
  • 1
  • 6
  • 21