确定图像跨浏览器的原始大小?

IT技术 javascript image
2021-02-05 22:48:25

是否有一种可靠的、独立于框架的方法来确定<img src='xyz.jpg'>客户端调整大小的物理尺寸

5个回答

您有 2 个选择:

选项1:

删除widthheight属性并读取offsetWidthoffsetHeight

选项 2:

创建一个 JavaScriptImage对象,设置src,然后读取widthheight(您甚至不必将它添加到页面来执行此操作)。

function getImgSize(imgSrc) {
    var newImg = new Image();

    newImg.onload = function() {
      var height = newImg.height;
      var width = newImg.width;
      alert ('The image size is '+width+'*'+height);
    }

    newImg.src = imgSrc; // this must be done AFTER setting onload
}

由 Pekka 编辑:正如评论中所同意的,我将函数更改为在图像的“onload”事件上运行。否则,大图像,heightwidth不会因为在拍摄时尚未加载任何回报。

@Gabriel,我正在使用它,但具有newImg.onload确保在设置宽度/高度时加载图像功能。你同意我相应地编辑你的答案吗?
2021-03-12 22:48:25
只是一个旁注:Chrome/OSX 可能会遇到缓存图像的问题,使用此技术将 0 作为高度/宽度。
2021-03-18 22:48:25
这不适用于尚未加载的图像。可能值得对其进行调整以使其其他人在此答案中跌跌撞撞地正常工作。
2021-03-26 22:48:25
@GabrielMcAdams,如果您if(newImg.complete || newImg.readyState === 4) newImg.onload();在函数末尾添加,它将解决 Chrome/OSX 上导致从缓存加载图像时不触发 onload 的问题。
2021-03-28 22:48:25
我如何获得返回高度和宽度...?? 因为这些变量没有超出 onload
2021-04-07 22:48:25

图像(至少在 Firefox 上)具有naturalWidth/height 属性,因此您可以使用它img.naturalWidth来获取原始宽度

var img = document.getElementsByTagName("img")[0];
img.onload=function(){
    console.log("Width",img.naturalWidth);
    console.log("Height",img.naturalHeight);
}

来源

这是 2018 年的获胜答案。适用于任何地方。(根据MDN 上的浏览器兼容性表。)
2021-03-19 22:48:25
该主题在 2013 年仍然相关。这是一个链接,其中包含适用于 IE7/8 的出色解决方法:jacklmoore.com/notes/naturalwidth-and-naturalheight-in-ie
2021-04-06 22:48:25

您可以将图像预加载到 javascript Image 对象中,然后检查该对象的宽度和高度属性。

当然 - 我不必将其放入文档中。会那样做,干杯!
2021-03-13 22:48:25
/* Function to return the DOM object's in crossbrowser style */
function widthCrossBrowser(element) {
    /* element - DOM element */

    /* For FireFox & IE */
    if(     element.width != undefined && element.width != '' && element.width != 0){
        this.width  =   element.width;
    }
    /* For FireFox & IE */
    else if(element.clientWidth != undefined && element.clientWidth != '' && element.clientWidth != 0){
        this.width  =   element.clientWidth;
    }
    /* For Chrome * FireFox */
    else if(element.naturalWidth != undefined && element.naturalWidth != '' && element.naturalWidth != 0){
        this.width  =   element.naturalWidth;
    }
    /* For FireFox & IE */
    else if(element.offsetWidth != undefined && element.offsetWidth != '' && element.offsetWidth != 0){
        this.width  =   element.offsetWidth;
    }       
        /*
            console.info(' widthWidth width:',      element.width);
            console.info(' clntWidth clientWidth:', element.clientWidth);
            console.info(' natWidth naturalWidth:', element.naturalWidth);
            console.info(' offstWidth offsetWidth:',element.offsetWidth);       
            console.info(' parseInt(this.width):',parseInt(this.width));
        */
    return parseInt(this.width);

}   

var elementWidth    = widthCrossBrowser(element);
elementjQuery 选择?什么是高度?
2021-03-18 22:48:25

只需稍微更改 Gabriel 的第二个选项,使其更易于使用:

function getImgSize(imgSrc, callback) {
    var newImg = new Image();

    newImg.onload = function () {
        if (callback != undefined)
            callback({width: newImg.width, height: newImg.height})
    }

    newImg.src = imgSrc;
}

网址:

<img id="_temp_circlePic" src="http://localhost/myimage.png" 
style="width: 100%; height:100%">

示例调用:

getImgSize($("#_temp_circlePic").attr("src"), function (imgSize) {
    // do what you want with the image's size.
    var ratio = imgSize.height / $("#_temp_circlePic").height();
});