2

Is there any trick to set the font-size as big as possible so that the text will always fit the windows width?

I tried to use vw but I'm sure CCS is much more rich than that.

.font{
font-family:Arial;
font-size:7vw;
display:table;
height:100vh;
width:100vw;
}

.inner{
display:table-cell;
vertical-align:middle;
text-align:center;

}
<div class=font>
<div class=inner>abcdefghijklmnopqrstuvwxyz</div>
</div>

Thanks in advance.

Federico
  • 1,392
  • 1
  • 17
  • 40
  • 1
    _“but I'm sure CCS is much more rich than that”_ - it isn’t, not in this particular regard. For a text of a static length you might be able to find an approximately working value using a unit such as `vw`, but if you need this for dynamic text of unknown length, then the only thing you can do is use a script that starts with a small font size and increases it in steps, checking how long the text still “fits.” – misorude Oct 16 '18 at 08:11
  • 2
    Question is old, but take a look in here -> https://stackoverflow.com/questions/16056591/font-scaling-based-on-width-of-container – Sebastian Thadewald Oct 16 '18 at 08:12

1 Answers1

1

Well, your code is already pretty smart. I really don't see any improvements we could build on.

You should definitely check this question, pointing to a Jquery plugin that seems to be really handy: Auto-size dynamic text to fill fixed size container.

So, let's take it as the first solution:

body {
  margin: 0;
}

.font {
  font-family: Arial;
  font-size: 49vw;
  display: table;
  height: 100vh;
  width: 100vw;
  margin: 0;
}

.inner {
  display: table-cell;
  vertical-align: middle;
  text-align: center;
}
<div class=font>
  <div class=inner>glee</div>
</div>

What I could suggest (although it's pretty bad for semantics, screen readers...) is maybe experimenting with a background image and background-size: contain;. Be sure to use SVG text!

body {
  margin: 0;
}

.font {
  font-family: Arial;
  font-size: 6vw;
  display: table;
  height: 100vh;
  width: 100vw;
  margin: 0;
}

.inner {
  display: table-cell;
  background: center no-repeat;
  background-size: contain;
  background-image: url()
}
<div class=font>
  <div class=inner></div>
</div>

And, just in case, you may want to add word-break: break-all, to ensure that even if the font is not loaded correctly for whatever reason, the text is still readable.

Puka
  • 1,485
  • 1
  • 14
  • 33