html5拖拽图片上传,怎么获得图片原始尺寸

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了html5拖拽图片上传,怎么获得图片原始尺寸相关的知识,希望对你有一定的参考价值。

fileList = e.dataTransfer.files;这句话得到的文件对象中没有图像的尺寸信息,但如果我想根据图像原始尺寸来定制防止图片的框的尺寸,该怎么办

拖拽的过程就不说了,这里主要说一下如何在前端获取到图片的相关信息。

html5里有一个fileReader的全局变量,用来读取本地文件,比如txt,img等,下面是一个简单的代码。

function checkFile(files)
var file = files[0];
var reader = new FileReader();
// show表示<div id='show'></div>,用来展示图片预览的
if(!/image\\/\\w+/.test(file.type))
            show.innerHTML = "请确保文件为图像类型";
            return false;
        
        // onload是异步操作
reader.onload = function(e)
show.innerHTML = '<img src="'+e.target.result+'" alt="img">';

reader.readAsDataURL(file);

这样就能够在不上传到服务器的前提下预览图片。当然,这个问题的重点是获取图片的原始尺寸,html5里还提供了两个变量来获取:naturalWidth和naturalHeight,这两个分别来获取图片的原始宽度和原始高度。


在上面的例子中,就能通过下面的方式获取到:

var width = e.target.naturalWidth;
var height = e.target.naturalHeight;



还有一种情况就是,如果已经存在页面里的图片,怎么获取到原始尺寸呢,可以这样:

var img = document.getElementsByTagName('img')[0]; // 获取到图片
var width = img.naturalWidth;
var height = img.naturalHeight;

参考技术A 用后台语言去获取不就可以了。为什么一定要在前端来获取图片原始大小呢?即使你要在前端实用,比如php获取到了以后还是可以通过变量传递给前端的。至于PHP怎么获取图片原始大小这个网上很容易找到资料!

thinkphp上传图片如何检验尺寸?

我说的是如何检验图片的长宽比例,比如:只能上传1002*60的图片,该怎么验证?

用getimagesize方法,如下示例:

HTML页面

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>定义input type="file" 的样式</title>
<style type="text/css">
body font-size:14px;
input vertical-align:middle; margin:0; padding:0
.file-box position:relative;width:340px
.txt height:22px; border:1px solid #cdcdcd; width:180px;cursor: pointer;
.btn background-color:#FFF; border:1px solid #CDCDCD;height:24px; width:70px;cursor: pointer;
.file position:absolute; top:0; right:80px; height:24px; filter:alpha(opacity:0);opacity: 0;width:260px;cursor: pointer;
</style>
</head>
<body>
<div class="file-box">
    <form action="test.php" method="post" enctype="multipart/form-data">
        <input type='text' name='textfield' id='textfield' class='txt' />  
        <input type='button' class='btn' value='浏览...' />
        <input type="file" name="fileField" class="file" id="fileField" size="28" onchange="document.getElementById('textfield').value=this.value" />
        <input type="submit" name="submit" class="btn" value="上传" />
    </form>
</div>
</body>
</html>

 PHP页面:

<?php
echo "<pre>";
print_r($_FILES);
echo "<br />";
$size = getimagesize($_FILES['fileField']['tmp_name']);
echo "<pre>";
print_r($size);
?>

 demo效果示意图

点击浏览选择图片,然后点击上传后的输出

第二个输出的数组有你需要的相关数据。

看看是否符合你的需求?若有疑问,欢迎追问!

参考技术A thinkphp上传图片不用我们去考虑如何检验尺寸,只需设置下就可以了:
$upload = new \Think\Upload();// 实例化上传类
$upload->maxSize = 3145728 ;// 设置附件上传大小(字节为单位)
// ... ...

$upload = new \Think\Upload(array(
'maxSize' => 3145728, // 设置附件上传大小(字节为单位)
// ... ...

));// 实例化上传类
然后当尺寸不符时用getError()获得信息.
$info = $upload->upload(); // 上传文件
if(!$info) // 上传错误提示错误信息
$this->error($upload->getError());
else// 上传成功 获取上传文件信息
foreach($info as $file)
echo $file['savepath'].$file['savename'];

参考技术B 判断图片的长和宽

以上是关于html5拖拽图片上传,怎么获得图片原始尺寸的主要内容,如果未能解决你的问题,请参考以下文章

Html5移动端上传图片并裁剪 - Clipic.js

如何制作ICO文件?

js获取图片原始尺寸

怎么用jsp实现拖拽上传图片?

用java怎么获得一张图片上的一个文字的坐标点 求高手解答

请问上传图片时尺寸过大该怎么办??