我正在尝试使用image.width
和image.height
来获取在JS中创建的SVG元素的高度/宽度。
在Chrome(最新版)上,这会返回宽度和高度,两个base64编码的SVG和数据URI都是image.src
。
但是,在Firefox(最新版)上,即使我设置了0
侦听器,这些都会返回image.onload
。
// base64 encoded SVG - EXPECTED 250x150
const base64String = new Image();
base64String.src = "";
base64String.onload = function() {
console.log(base64String.width, base64String.height); // Returns 250 150 on Chrome, 0 0 on FF
};
here's a JSBin显示问题。在Chrome和FF中打开它以查看不同的输出。那里还有一个.jpg作为控件也适用于两者。
答案 0 :(得分:1)
经过一些研究后,似乎浏览器在没有尺寸的情况下为SVG提供了一些默认值,同时保留了宽高比,Chrome为350x150。 Firefox会为这些值返回0。 source