我建议如下:
document.getElementById('display-date').style.fontSize = '2em'; // or whatever measurement.
而且,因为我有一些时间,这里有一个函数:
function fontSizeChange(elem, factor) {
if (!elem) {
return false;
}
else {
factor = factor || 2; // 2 is the default
elem = elem.nodeType && elem.nodeType === 1 ? elem : document.getElementById(elem);
var cur = window.getComputedStyle(elem, null).fontSize,
size = parseInt(cur.replace(/\D+/g,''),10),
unit = cur.replace(/\d+/g,'');
elem.style.fontSize = (size * factor) + unit;
}
}
像这样调用:
fontSizeChange('display-date', 3);
JS 小提琴演示。
或者:
fontSizeChange(document.getElementById('display-date'), 4);
JS 小提琴演示。
或者(如果要使用默认设置,可以省略factor
参数):
fontSizeChange('display-date');
JS 小提琴演示。
而且,当然,你也可以缩小 thngs:
fontSizeChange('display-date',0.25);
JS 小提琴演示。
当然,您也可以使用 CSS:
#display-date {
font-size: 2em;
}
JS 小提琴演示。
允许将调整大小附加到返回的元素 ( document.querySelector()
/ document.getElementById()
) 或节点列表 ( document.getElementsByTagName()
/ document.querySelectorAll()
) 的更新版本:
Object.prototype.resize = function (prop, factor) {
if (prop) {
factor = parseFloat(factor) || 2;
var self = this.length ? this : [this],
cur, size, unit;
for (var i = 0, len = self.length; i < len; i++) {
var cur = window.getComputedStyle(self[i],null)[prop],
size = parseFloat(cur.replace(/\D/g,'')),
unit = cur.replace(/\d+/g,'');
self[i].style[prop] = (size * factor) + unit;
}
}
return this;
};
document.getElementsByTagName('div').resize('width',3);
document.getElementById('display-date').resize('font-size', 2.5);
JS 小提琴演示。
Object.prototype.resize = function (prop, factor) {
if (prop) {
factor = parseFloat(factor) || 2;
var self = this.length ? this : [this],
cur, size, unit;
for (var i = 0, len = self.length; i < len; i++) {
var cur = window.getComputedStyle(self[i],null)[prop],
size = parseFloat(cur.replace(/\D/g,'')),
unit = cur.replace(/\d+/g,'');
self[i].style[prop] = (size * factor) + unit;
}
}
return this;
};
document.querySelectorAll('div').resize('height',3);
document.querySelector('#display-date').resize('font-size', 0.5);
JS 小提琴演示。
参考: