JavaScript检测上传文件大小的方法


Posted in Javascript onJuly 22, 2015

本文实例讲述了JavaScript检测上传文件大小的方法。分享给大家供大家参考。具体如下:

通过JS客户端代码限制用户上传文件的大小,但是客户端的验证只是辅助的,服务器端一定还要再做验证

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <meta name="DEscription" contect="my code demo" />
 <meta name="Author" contect="Michael@3water.com" />
 <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
 <title>js check file size @ 3water.com</title>
 </head>
 <body>
  <img id="tempimg" dynsrc="" src="" style="display:none" />
  <input type="file" name="file" id="fileuploade" size="40" />
  <input type="button" name ="check" value="checkfilesize" onclick="checkfile()"/>
 </body>
 <script type="text/javascript">
  var maxsize = 2*1024*1024;//2M
  var errMsg = "上传的附件文件不能超过2M!!!";
  var tipMsg = "您的浏览器暂不支持计算上传文件的大小,确保上传文件不要超过2M,建议使用IE、FireFox、Chrome浏览器。";
  var browserCfg = {};
  var ua = window.navigator.userAgent;
  if (ua.indexOf("MSIE")>=1){
   browserCfg.ie = true;
  }else if(ua.indexOf("Firefox")>=1){
   browserCfg.firefox = true;
  }else if(ua.indexOf("Chrome")>=1){
   browserCfg.chrome = true;
  }
  function checkfile(){
   try{
     var obj_file = document.getElementById("fileuploade");
     if(obj_file.value==""){
      alert("请先选择上传文件");
      return;
     }
     var filesize = 0;
     if(browserCfg.firefox || browserCfg.chrome ){
      filesize = obj_file.files[0].size;
     }else if(browserCfg.ie){
      var obj_img = document.getElementById('tempimg');
      obj_img.dynsrc=obj_file.value;
      filesize = obj_img.fileSize;
     }else{
      alert(tipMsg);
     return;
     }
     if(filesize==-1){
      alert(tipMsg);
      return;
     }else if(filesize>maxsize){
      alert(errMsg);
      return;
    }else{
     alert("文件大小符合要求");
      return;
    }
   }catch(e){
    alert(e);
   }
  }
 </script>
</html>

希望本文所述对大家的javascript程序设计有所帮助。

Javascript 相关文章推荐
详解Bootstrap四种图片样式
Jan 04 Javascript
使用Object.defineProperty实现简单的js双向绑定
Apr 15 Javascript
JavaScript基础语法之js表达式
Jun 07 Javascript
谈谈target=_new和_blank的不同之处
Oct 25 Javascript
基于JS实现横线提示输入验证码随验证码输入消失(js验证码的实现)
Oct 27 Javascript
JavaScript实现三级联动菜单实例代码
Jun 26 Javascript
深入理解vue中的slot与slot-scope
Apr 22 Javascript
Vue 实现显示/隐藏层的思路(加全局点击事件)
Dec 31 Javascript
解决Vue中的生命周期beforeDestory不触发的问题
Jul 21 Javascript
js实现拖拽元素选择和删除
Aug 25 Javascript
原生JS实现音乐播放器
Jan 26 Javascript
Canvas三种动态画圆实现方法说明(小结)
Apr 16 Javascript
JavaScript动态改变div属性的实现方法
Jul 22 #Javascript
PHP结合jQuery实现的评论顶、踩功能
Jul 22 #Javascript
PHP结合jQuery实现红蓝投票功能特效
Jul 22 #Javascript
用Move.js配合创建CSS3动画的入门指引
Jul 22 #Javascript
js判断手机端(Android手机还是iPhone手机)
Jul 22 #Javascript
javascript实现网页屏蔽Backspace事件,输入框不屏蔽
Jul 21 #Javascript
Javascript实现获取及设置光标位置的方法
Jul 21 #Javascript
You might like
用php实现选择排序的解决方法
2013/05/04 PHP
PHP函数之日期时间函数date()使用详解
2013/09/09 PHP
Zend studio文件注释模板设置方法
2013/09/29 PHP
解决php接收shell返回的结果中文乱码问题
2014/01/23 PHP
PHP 5.3新增魔术方法__invoke概述
2014/07/23 PHP
PHP MSSQL 分页实例
2016/04/13 PHP
发一个自己用JS写的实用看图工具实现代码
2008/07/26 Javascript
js 提交和设置表单的值
2008/12/19 Javascript
JQuery扩展插件Validate 2通过参数设置验证规则
2011/09/05 Javascript
javascript 全选与全取消功能的实现代码
2012/12/23 Javascript
浅析jquery ajax异步调用方法中不能给全局变量赋值的原因及解决方法
2014/01/10 Javascript
使用CSS3的scale实现网页整体缩放
2014/03/18 Javascript
纯css实现窗户玻璃雨滴逼真效果
2015/08/23 Javascript
JS获取html元素的标记名实现方法
2016/10/08 Javascript
BootStrap Fileinput插件和Bootstrap table表格插件相结合实现文件上传、预览、提交的导入Excel数据操作步骤
2017/08/07 Javascript
vue-cli中打包图片路径错误的解决方法
2017/10/26 Javascript
vue.js实现备忘录demo
2019/06/26 Javascript
JavaScript获取某一天所在的星期
2019/09/05 Javascript
JavaScript实现省市联动效果
2019/11/22 Javascript
Vue 实现登录界面验证码功能
2020/01/03 Javascript
python实现颜色rgb和hex相互转换的函数
2015/03/19 Python
使用python生成目录树
2018/03/29 Python
Python操作mongodb数据库进行模糊查询操作示例
2018/06/09 Python
解决Django Static内容不能加载显示的问题
2019/07/28 Python
Python 类的私有属性和私有方法实例分析
2019/09/29 Python
python的Jenkins接口调用方式
2020/05/12 Python
Python可以实现栈的结构吗
2020/05/27 Python
python 偷懒技巧——使用 keyboard 录制键盘事件
2020/09/21 Python
使用python操作lmdb对数据读取的实例
2020/12/11 Python
详解webapp页面滚动卡顿的解决办法
2018/12/26 HTML / CSS
Rentalcars.com中国:世界上最大的在线汽车租赁服务
2019/08/22 全球购物
戴尔新加坡官网:Dell Singapore
2020/12/13 全球购物
Linux上比较文件的命令都有哪些
2013/09/28 面试题
《晏子使楚》教学反思
2014/02/08 职场文书
Python实现Telnet自动连接检测密码的示例
2021/04/16 Python
浅谈Python3中datetime不同时区转换介绍与踩坑
2021/08/02 Python