js判斷文件類(lèi)型大小并給出提示的實(shí)現(xiàn)方法
更新時(shí)間:2018年01月03日 09:34:47 作者:誰(shuí)將新樽辭舊月,今月曾經(jīng)照古人
下面小編就為大家分享一篇js判斷文件類(lèi)型大小并給出提示的實(shí)現(xiàn)方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
上傳文件是工作中常用的功能,不同的場(chǎng)景對(duì)不同的文件類(lèi)型和文件大小都有不同的要求:
<form id="uploadForm" method="post" class="layui-form"> <div class="layui-form-item"> <label class="layui-form-label">名稱(chēng)</label> <div class="layui-input-block"> <input type="text" name="name" required lay-verify="required" placeholder="請(qǐng)輸入文件名" autocomplete="off" class="layui-input"> </div> </div> <div class="layui-form-item"> <label class="layui-form-label">資料類(lèi)型:</label> <div class="layui-input-block"> <select name="datatypeid" id="datatypeid"></select> </div> <input type="hidden" id="yincang"> </div> <div class="layui-form-item"> <label class="layui-form-label">上傳文件</label> <div class="layui-input-block"> <input class="layui-input" type="file" name="file" onchange="fileChange(this);"/> </div> </div> <div class="layui-form-item"> <div class="layui-input-block"> <input type="button" class="layui-btn" value="上傳" onclick="upload()" /> </div> </div> </form>
js方法:
<script type="text/javascript">
var isIE = /msie/i.test(navigator.userAgent) && !window.opera;
function fileChange(target, id) {
var fileSize = 0;
var filetypes = [ ".doc", ".docx" ];//這里設(shè)置接受的文件類(lèi)型
var filepath = target.value;
var filemaxsize = 1024 * 10;//接受的文件最大10M
if (filepath) {
var isnext = false;
var fileend = filepath.substring(filepath.indexOf("."));
if (filetypes && filetypes.length > 0) {
for (var i = 0; i < filetypes.length; i++) {
if (filetypes[i] == fileend) {
isnext = true;
break;
}
}
}
if (!isnext) {
alert("不接受此文件類(lèi)型!");
target.value = "";
return false;
}
} else {
return false;
}
if (isIE && !target.files) {
var filePath = target.value;
var fileSystem = new ActiveXObject("Scripting.FileSystemObject");
if (!fileSystem.FileExists(filePath)) {
alert("附件不存在,請(qǐng)重新輸入!");
return false;
}
var file = fileSystem.GetFile(filePath);
fileSize = file.Size;
} else {
fileSize = target.files[0].size;
}
var size = fileSize / 1024;
if (size > filemaxsize) {
alert("附件大小不能大于" + filemaxsize / 1024 + "M!");
target.value = "";
return false;
}
if (size <= 0) {
alert("附件大小不能為0M!");
target.value = "";
return false;
}
}
</script>
以上這篇js判斷文件類(lèi)型大小并給出提示的實(shí)現(xiàn)方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
如何快速的呈現(xiàn)我們的網(wǎng)頁(yè)的技巧整理
如何快速的呈現(xiàn)我們的網(wǎng)頁(yè)的技巧整理...2007-07-07
淺析如何利用JavaScript進(jìn)行語(yǔ)音識(shí)別
所謂語(yǔ)音識(shí)別就是將你所說(shuō)的轉(zhuǎn)化成文字。Chrome 瀏覽器在版本25之后開(kāi)始對(duì)這一特性的支持。這篇文章將會(huì)詳細(xì)的介紹如何使用JavaScript進(jìn)行語(yǔ)音識(shí)別,感興趣的朋友們可以參考借鑒,下面來(lái)一起看看吧。2016-10-10
javascript 中模板方法單例的實(shí)現(xiàn)方法
這篇文章主要介紹了javascript 中模板方法單例的實(shí)現(xiàn)方法的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下2017-10-10
javascript實(shí)現(xiàn)的閉包簡(jiǎn)單實(shí)例
這篇文章主要介紹了javascript實(shí)現(xiàn)的閉包簡(jiǎn)單實(shí)現(xiàn)方法,涉及javascript閉包的原理與實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-07-07
js實(shí)現(xiàn)字符全排列算法的簡(jiǎn)單方法
下面小編就為大家?guī)?lái)一篇js實(shí)現(xiàn)字符全排列算法的簡(jiǎn)單方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-05-05

