<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Resizefont</title>
<style>
* {
box-sizing: border-box;
}
.child {
font-size: 1rem;
text-align: justify;
font-feature-settings: "palt";
}
</style>
</head>
<body>
<div>
<div class="child">
指定された文字数が収まるように文字サイズを調整する関数
</div>
</div>
<div style="width: 50vw">
<div class="child">
指定された文字数が収まるように文字サイズを調整する関数
</div>
</div>
<div style="width: 20vw;">
<div class="child">
指定された文字数が収まるように文字サイズを調整する関数
</div>
</div>
<script>
function adjustFontSizeToFitCharacters(childSelector, charCount) {
const children = document.querySelectorAll(childSelector);
children.forEach(child => {
const parent = child.parentElement;
if (parent) {
const parentWidth = parent.offsetWidth;
const fontSize = Math.floor(parentWidth / charCount);
child.style.fontSize = `${fontSize}px`;
child.style.lineHeight = 1.1;
}
});
}
adjustFontSizeToFitCharacters('.child', 10);
window.addEventListener('load', function () {
adjustFontSizeToFitCharacters('.child', 10);
});
window.addEventListener('resize', function () {
adjustFontSizeToFitCharacters('.child', 10);
});
</script>
</body>
</html>