如何用javascript控制上傳檔案的大小

來源:互聯網
上載者:User

複製代碼 代碼如下:<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")
{
checkSize();
}
}

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

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

複製代碼 代碼如下: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">

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.