28

到目前为止我有这个代码:

var img = document.getElementById('draggable');
var width = img.clientWidth;
var height = img.clientHeight;

然而,这让我获得了 html 属性 - css 样式。我想获取文件的实际图像资源的尺寸。

我需要这个,因为在上传图片时,它的宽度设置为 0px,我不知道为什么或在哪里发生这种情况。为了防止它,我想获得实际尺寸并重置它们。这可能吗?

编辑:即使我尝试获得 naturalWidth 我也得到 0 结果。我添加了一张图片。奇怪的是,它仅在我上传新文件并刷新时才会发生,它应该正常工作。

http://oi39.tinypic.com/3582xq9.jpg

4

3 回答 3

52

您可以使用naturalWidthand naturalHeight,这些属性包含图像的实际、未修改的宽度和高度,但您必须等到图像加载后才能获取它们

var img = document.getElementById('draggable');

img.onload = function() {
    var width  = img.naturalWidth;
    var height = img.naturalHeight;
}

仅IE9及以上版本支持,如果您必须支持旧浏览器,您可以创建一个新图像,将其来源设置为相同的图像,如果您不修改图像的大小,它将返回图像自然大小,因为当没有给出其他大小时,这将是默认值

var img     = document.getElementById('draggable'),
    new_img = new Image();

new_img.onload = function() {
    var width  = this.width,
        heigth = this.height;
}

new_img.src = img.src;

小提琴

于 2013-05-02T16:20:24.363 回答
18

img.naturalHeightimg.naturalWidth哪个给你图像本身的宽度和高度,而不是 DOM 元素。

于 2013-05-02T16:18:57.487 回答
5

您可以使用我制作的以下功能。

功能

function getImageDimentions(imageNode) {
  var source = imageNode.src;
  var imgClone = document.createElement("img");
  imgClone.src = source;
  return {width: imgClone.width, height: imgClone.height}
}

html:

<img id="myimage" src="foo.png">

像这样使用它

var image = document.getElementById("myimage"); // get the image element
var dimentions = getImageDimentions(image); // get the dimentions
alert("width: " + dimentions.width + ", height: " + dimentions.height); // give the user a visible alert of the dimentions
于 2015-12-01T14:36:59.727 回答