Есть несколько способов автоматически подгонять размер текста внутри блока div:
1. CSS с единицами rem/vw/vh: Вы можете использовать относительные единицы CSS, такие как rem (относительно размера корневого элемента), vw (относительно ширины окна просмотра) или vh (относительно высоты окна просмотра) для задания размера текста. Например, можно использовать свойство font-size: 1rem; для установки размера текста, а затем задать размер текста в root элементе (html) с использованием CSS переменных для автоматического изменения размера при изменении размера блока.
2. JavaScript с помощью события изменения размера окна: Вы можете использовать JavaScript для отслеживания изменения размера блока div и изменения размера текста соответствующим образом. Для этого вы можете привязать обработчик события изменения размера окна (resize) к элементу и использовать методы доступа к элементу и управления размером текста.
Вот пример приближенной реализации с помощью JavaScript:
```javascript
var div = document.getElementById("myDiv");
var text = document.getElementById("myText");
var size = 20; // начальный размер текста
function resizeText() {
var width = div.offsetWidth;
var height = div.offsetHeight;
var newSize = Math.min(width, height) * 0.1; // вычисление нового размера текста
text.style.fontSize = newSize + "px"; // применение нового размера текста
}
window.addEventListener("resize", resizeText);
```
В данном примере мы отслеживаем изменение размера окна и при изменении вызываем функцию `resizeText`, которая вычисляет новый размер текста, основываясь на размерах блока div, и применяет его к тексту.
Это лишь приближенный пример реализации, и вы можете настроить его под свои нужды, включая более сложные алгоритмы для определения размера текста.