js利用canvas测量文字的真实宽度

使用文字的大致像素,比如1em=12px,再计算文字的个数乘一下,得到的宽度不一定准确,因为文字之间还有间隙。今天看到别人代码里面,使用了canvas来进行测量,这里记录下来。下面的代码经过了修改,实现一个通用的函数:

function getTextWith(text, fontStyle) {
    var canvas = document.createElement('canvas')
    var context = canvas.getContext('2d')
    context.font = fontStyle || '16px' // 设置字体样式,当然,也可以在这里给一个默认值
    var dimension = context.measureText(text)
    return dimension.width
}
var textWidth = getTextWith('This is my dog!', '14px/1.6 "Microsoft Yahei"')
console.log(textWidth)

这样就可以得到这些字的真实宽度。而且,由于字体不同,这个高宽还会变,有些公司使用了自己的字体,文字的大小也会因为字体发生变化。但是用这种方法都可以测出来。

2017-03-21