自知其无知
不懂,慢慢懂。
posts - 2,comments - 2,trackbacks - 0

准备一个在客户端判断上传文件大小,限制大小的好方法,但是实在没有找到,
因为即使你用  Ajax ,可能结果还没有返回,表单就已经被提交了。。。
所以服务器必须重新判断。。。。

以下为弱弱的判断。。

<form name=Myform onsubmit="return CheckFileSize()">
<input type=file name=photo><br/>
<input type=submit value=submit></form>

<SCRIPT LANGUAGE="JavaScript"><!--
function CheckFileSize()
{
var s = document.Myform.photo.value;
if(s==" ")return false;
var img = new Image();
img.src = s;
alert("高 = " img.height "n宽 = " img.width);
alert("fileSize = " img.fileSize " 字节");
return false;
}
//--></SCRIPT>

应用了javascript和在IE下img本身的fileSize属性。另外img还有其他的几个属性,如fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我们可以通过这些属性来获取图片文件的部分信息,如文件大小,我们用file表单同img标签结合,就能够在上传之前判断图片文件的大小是否合法了。

限制:<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> K
<input type="file" name="file1" id="file1" size="40" onchange="changeSrc(this)"/>
<img src="about:blank" id="fileChecker" alt="test" height="18"/>

<script type="text/javascript">
var oFileChecker = document.getElementById("fileChecker");

function changeSrc(filePicker)
{
oFileChecker.src = filePicker.value;
}

oFileChecker.onreadystatechange = function ()
{
if (oFileChecker.readyState == "complete")

}

function checkSize()
{
var limit = document.getElementById("fileSizeLimit").value * 1024;

if (oFileChecker.fileSize > limit)
{
alert("too large");
}
else

}
</script>

我的一个项目里这样用(pendlehill)

function CheckFileSize()
{
var FileMaxSize = 100;//限制上传的文件大小,单位(k)
var s = document.RegForm.Img_1.value;
//if(s==""){alert("No image,please select again!");document.RegForm.Img_1.focus(); return false;}
var img = new Image();

img.src = s;

if(img.fileSize>FileMaxSize*1024){alert("The file size exceeds " FileMaxSize "K,please choose a smaller one!");document.RegForm.Img_1.focus();return false;}

//--></SCRIPT>

<FORM action="**.asp" method="post" onSubmit="return CheckFileSize()" enctype="multipart/form-data" name="RegForm">

<input name="Next" type="submit" class="pBttn" id="Next" value="Save">

<form name=Myform onsubmit="return CheckFileSize()">
<input type=file name=photo><br/>
<input type=submit value=submit></form>

<SCRIPT LANGUAGE="JavaScript"><!--
function CheckFileSize()
{
var s = document.Myform.photo.value;
if(s==" ")return false;
var img = new Image();
img.src = s;
alert("高 = " img.height "n宽 = " img.width);
alert("fileSize = " img.fileSize " 字节");
return false;
}
//--></SCRIPT>

应用了javascript和在IE下img本身的fileSize属性。另外img还有其他的几个属性,如fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我们可以通过这些属性来获取图片文件的部分信息,如文件大小,我们用file表单同img标签结合,就能够在上传之前判断图片文件的大小是否合法了。

限制:<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> K
<input type="file" name="file1" id="file1" size="40" onchange="changeSrc(this)"/>
<img src="about:blank" id="fileChecker" alt="test" height="18"/>

<script type="text/javascript">
var oFileChecker = document.getElementById("fileChecker");

function changeSrc(filePicker)
{
oFileChecker.src = filePicker.value;
}

oFileChecker.onreadystatechange = function ()
{
if (oFileChecker.readyState == "complete")

}

function checkSize()
{
var limit = document.getElementById("fileSizeLimit").value * 1024;

if (oFileChecker.fileSize > limit)
{
alert("too large");
}
else

}
</script>

我的一个项目里这样用(pendlehill)

function CheckFileSize()
{
var FileMaxSize = 100;//限制上传的文件大小,单位(k)
var s = document.RegForm.Img_1.value;
//if(s==""){alert("No image,please select again!");document.RegForm.Img_1.focus(); return false;}
var img = new Image();

img.src = s;

if(img.fileSize>FileMaxSize*1024){alert("The file size exceeds " FileMaxSize "K,please choose a smaller one!");document.RegForm.Img_1.focus();return false;}

//--></SCRIPT>

<FORM action="**.asp" method="post" onSubmit="return CheckFileSize()" enctype="multipart/form-data" name="RegForm">

<input name="Next" type="submit" class="pBttn" id="Next" value="Save">


posted on 2008-12-11 23:51 CopyHoo 阅读(1567) 评论(0)  编辑  收藏 所属分类: JavaScript

只有注册用户登录后才能发表评论。


网站导航: