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 相关文章推荐
一段实时更新的时间代码
Jul 07 Javascript
Jquery多选下拉列表插件jquery multiselect功能介绍及使用
May 24 Javascript
JavaScript设计模式开发中组合模式的使用教程
May 18 Javascript
JS简单封装的图片无缝滚动效果示例【测试可用】
Mar 22 Javascript
vue.js父组件使用外部对象的方法示例
Apr 25 Javascript
JavaScript之filter_动力节点Java学院整理
Jun 28 Javascript
node的process以及child_process模块学习笔记
Mar 06 Javascript
解决node-sass偶尔安装失败的方法小结
Dec 05 Javascript
微信小程序实现的绘制table表格功能示例
Apr 26 Javascript
Vue实现固定定位图标滑动隐藏效果
May 30 Javascript
node实现简单的增删改查接口实例代码
Aug 22 Javascript
微信小程序canvas截取任意形状的实现代码
Jan 13 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/06/05 PHP
简单概括PHP的字符串中单引号与双引号的区别
2016/05/07 PHP
PHP记录和读取JSON格式日志文件
2016/07/07 PHP
php实现购物车产品删除功能(2)
2020/07/23 PHP
JavaScript DOM 编程艺术(第2版)读书笔记(JavaScript的最佳实践)
2013/10/01 Javascript
iframe子页面与父页面在同域或不同域下的js通信
2014/05/07 Javascript
JS模拟Dialog弹出浮动框效果代码
2015/10/16 Javascript
Jquery检验手机号是否符合规则并根据手机号检测结果将提交按钮设为不同状态
2015/11/26 Javascript
基于javascript实现图片预加载
2016/01/05 Javascript
jQuery中$.each()函数的用法引申实例
2016/05/12 Javascript
详解JavaScript的内置对象
2016/12/07 Javascript
angularjs点击图片放大实现上传图片预览
2017/02/24 Javascript
angular 基于ng-messages的表单验证实例
2017/05/04 Javascript
解决Extjs下拉框不显示的问题
2017/06/21 Javascript
利用node.js爬取指定排名网站的JS引用库详解
2017/07/25 Javascript
js学习总结之DOM2兼容处理this问题的解决方法
2017/07/27 Javascript
Node.js 使用流实现读写同步边读边写功能
2017/09/11 Javascript
jquery在启动页面时,自动加载数据的实例
2018/01/22 jQuery
JavaScript的Proxy可以做哪些有意思的事儿
2019/06/15 Javascript
2020淘宝618理想生活列车自动领喵币js脚本的代码
2020/06/02 Javascript
Python3实现简单可学习的手写体识别(实例讲解)
2017/10/21 Python
Django保护敏感信息的方法示例
2019/05/09 Python
python urllib爬虫模块使用解析
2019/09/05 Python
python爬虫学习笔记之Beautifulsoup模块用法详解
2020/04/09 Python
Python 找出英文单词列表(list)中最长单词链
2020/12/14 Python
python中time、datetime模块的使用
2020/12/14 Python
python热力图实现简单方法
2021/01/29 Python
python 如何在测试中使用 Mock
2021/03/01 Python
html5 乒乓球(碰撞检测)实例二
2013/07/25 HTML / CSS
Expedia挪威官网:酒店、机票和租车
2018/03/03 全球购物
美国糖果店:Sugarfina
2019/02/21 全球购物
教导处工作制度
2014/01/18 职场文书
2015年个人实习工作总结
2014/12/12 职场文书
社区服务活动报告
2015/02/05 职场文书
志愿者服务宣传标语口号
2015/12/26 职场文书
2019年让高校“心动”的自荐信
2019/03/25 职场文书