参考上面回答 transform: scale();
Font Size Auto Fit.container {width:100%;height:2em;line-height:2em;font-size:24px;border:2px solid black;overflow:hidden;}
.container .text {display:inline-block;line-height:2em;white-space:nowrap;background-color:#FCC;transform-origin:left center;}
input[name="text"] {display:block;margin:1em 0;width:100%;height:2em;line-height:2em;font-size:24px;box-sizing:border-box;}
document.addEventListener('DOMContentLoaded', function(){
let domContainer = document.querySelector('.container');
let domText = domContainer.querySelector('.text');
function update_text()
{
if(domText.clientWidth <= domContainer.clientWidth)
{
domText.style.transform = 'none';
}
else
{
let r = domContainer.clientWidth/domText.clientWidth;
domText.style.transform = 'scale('+r+')';
}
}
document.querySelector('input[name="btnUpdate"]').addEventListener('click', function(){
domText.innerHTML = document.querySelector('input[name="text"]').value;
update_text();
});
update_text();
});