获得浏览器最小字体大小的最佳方法是什么?我编写了以下代码,它执行二进制搜索。它有效,但我想知道是否有标准或更有效的方法。
function getMinimumFontSize() {
var el = document.createElement('div');
document.body.appendChild(el);
el.innerHTML = "<div><p>a b c d e f g h i j k l m n o p q r s t u v w x y z</p></div>";
el.style.fontSize = '1px';
el.style.width = '64px';
var minimumHeight = el.offsetHeight;
var least = 0;
var most = 64;
var middle;
for (var i = 0; i < 32; ++i) {
middle = (least + most)/2;
el.style.fontSize = middle + 'px';
if (e.offsetHeight === minimumHeight) {
least = middle;
} else {
most = middle;
}
}
return middle;
}
仅仅设置样式并将其读回是行不通的,因为它将返回设置而不是浏览器实际使用的内容。
我需要最小字体大小,以便我可以动态调整内容大小以将所有内容保持在一页上,而无需滚动。如果浏览器忽略了我的字体大小更改,这很难做到,因为我已经低于最小值。所以对于这种情况,我会缩小其他内容,比如图形。