学习使用AngularJS文件上传控件


Posted in Javascript onFebruary 16, 2016

前段时间做项目遇到一个需求是上传文件,大概需要实现的样式是这样子的,见下图:

学习使用AngularJS文件上传控件

需要同时上传两个文件。并且规定文件格式和文件大小。因为前端框架使用angular,且不想因为一个上传功能又引入一个jquery,所以在网上查找基于angular的上传控件,因为angular还算比较新,貌似都没有太成熟的插件,网上的教程也大多是复制粘贴,总之没起倒多大的作用...但是皇天不负有心人,最后还是让我遇到了这个功能强大的插件,让我有种相见恨晚的感觉呀,依靠官方文档和师兄的帮助,终于搞清楚了基本的使用方法。好东西要分享,所以现在跟大家分享一下他的使用方法,如果大家正好需要使用,希望能帮到大家。

上传按钮的样式
首先我想先说一下上传文件的按钮样式,为什么呢?大家都知道上传会用到这个标签。<input type="file"/>,这行代码的默认样式真的有点不好看,见下图:

学习使用AngularJS文件上传控件

在一个稍微有点逼格的网站中,这样一个样式实在是有点损失形象了,而且如果需要在前面加一个输入框来显示文件名的话,那默认的显示文件名的区域怎么隐藏掉呢?别急,继续看:

用一个a标签包住input标签,然后把input标签的opacity设为0,就可以了嘛!ok,看代码:

html:

<div>
 <input class="filename" type="text" readonly="readonly" />
 <a href="javascript:;" name="file">
  <input type="file" name="key"/>浏览
 </a>
 </div>
 <div>
 <input class="filename" type="text" readonly="readonly" />
 <a href="javascript:;" name="file">
  <input type="file" name="key"/>浏览
 </a>
 </div>

然后是css文件:

.filename{
 width: 300px;
 height: 30px;
 line-height: 30px;
}
a{
 width: 50px;
 text-align: center;
 height: 30px;
 line-height: 30px;
 position: raletive;
 cursor: pointer;
 overflow:hidden;
 display: inline-block;
}
a input{
 position: absolute:
 left: 0;
 top: 0;
 opacity: 0;
}

大功告成了!!!你看到的样式就变成了这样了,见下图:

学习使用AngularJS文件上传控件

你可以控制前面的输入框来显示你选择了的文件名,是不是好看多了呢?

学习使用AngularJS文件上传控件

angular-file-upload

例子中能够找到我们需要的文件。例子中的es5-shim.min.js文件是为老的浏览器兼容而引入的,所以这个插件真的很强大呀。

然后我们来一步步使用这个插件来实现文件上传的功能吧。

这个插件定义了几个指令:nv-file-drop、nv-file-select、uploader

从单词意思来看应该不难猜出,第一个支持文件脱拽选择,第二个是点击选择,uploader用于绑定在控制器中新建的upload对象。

html文件

<form class="form-horizontal" name="form">
 <div class="form-line">
 <label>请选择证书文件:</label><span class="small-tip">证书文件只支持.pem格式,文件大小1M以内</span>
 <div class="choose-file-area">
  <input class="file-name" type="text" readonly="readonly" ng-model="fileItem.name"/>
  <a href="javascript:;" class="choose-book">
  <input type="file" name="certificate" nv-file-select uploader="uploader" ng-click="clearItems()"/>浏览
  </a>
 </div>
 </div>
 <div class="form-line">
 <label>请选择私钥文件:</label><span class="small-tip">私钥文件只支持.key格式,文件大小1M以内</span>
 <div class="choose-file-area">
  <input class="file-name" type="text" readonly="readonly" ng-model="fileItem1.name"/>
  <a href="javascript:;" class="choose-key">
  <input type="file" name="key" nv-file-select uploader="uploader1" ng-click="clearItems1()"/>浏览
  </a>
 </div>
 </div>
 <button type="submit" ng-click="UploadFile()">提交</button>
</form>

首先,注意这里需要上传两个文件,所以我创建两个upload对象,方便管理文件和处理回调函数。最后给上传按钮一个点击事件,同时处理两个对象的上传事件。

控制器文件

var app = angular.module('app', ['angularFileUpload']);
app.controller('uploadController',['$scope', 'FileUploader', function($scope, FileUploader) {
 $scope.uploadStatus = $scope.uploadStatus1 = false; //定义两个上传后返回的状态,成功获失败
 var uploader = $scope.uploader = new FileUploader({
 url: 'upload.php',
 queueLimit: 1, //文件个数 
 removeAfterUpload: true //上传后删除文件
 });
 var uploader1 = $scope.uploader1 = new FileUploader({
 url: 'upload.php',
 queueLimit: 1,
 removeAfterUpload: true 
 });
 $scope.clearItems = function(){ //重新选择文件时,清空队列,达到覆盖文件的效果
 uploader.clearQueue();
 }
 $scope.clearItems1 = function(){
 uploader1.clearQueue();
 }
 uploader.onAfterAddingFile = function(fileItem) {
 $scope.fileItem = fileItem._file; //添加文件之后,把文件信息赋给scope
 };
 uploader1.onAfterAddingFile = function(fileItem) {
 $scope.fileItem1 = fileItem._file; //添加文件之后,把文件信息赋给scope
 //能够在这里判断添加的文件名后缀和文件大小是否满足需求。
 };
 uploader.onSuccessItem = function(fileItem, response, status, headers) {
 $scope.uploadStatus = true; //上传成功则把状态改为true
 };
 uploader1.onSuccessItem = function(fileItem,response, status, headers){
 $scope.uploadStatus1 = true;
 }
 $scope.UploadFile = function(){
 uploader.uploadAll();
 uploader1.uploadAll();
 if(status){
  if(status1){
  alert('上传成功!');
  }else{
  alert('证书成功!私钥失败!');
  }
 }else{
  if(status1){
  alert('私钥成功!证书失败!');
  }else{
  alert('上传失败!');
  }
 }
 }
}])

总结
在上面的例子中,我定义了两个upload对象是因为要上传两个文件,每一次重新选择文件时应该覆盖之前选好的文件,所以如果定义一个对象时,有点不好操作覆盖的位置,而定义两个对象,在重新选择的时候,完全可以先清空当前对象的文件队列,再添加就好了。

其实后来我发现,也可以不定义两个upload对象,因为这个插件提供了一个removeFromQueue(index)方法,index是文件队列数组中文件的index值。因为是两次选择文件,所以把长度控制在2,然后每次选择的时候调用这个方法,根据位置传入0或者1就好了。

如果需要实现同一个窗口能够多选文件,使用加上<input type="file" multiple="true" />即可。

如果需要限制文件类型,可以使用<input type="file" accept="image/*" />'即可。

accept取值类型列表:

* accept="application/msexcel"

* accept="application/msword"

* accept="application/pdf"

* accept="application/poscript"

* accept="application/rtf"

* accept="application/x-zip-compressed"
 
* accept="audio/basic"

* accept="audio/x-aiff"

* accept="audio/x-mpeg"

* accept="audio/x-pn/realaudio"

* accept="audio/x-waw"

* accept="image/*"

* accept="image/gif"
 
* accept="image/jpeg"

* accept="image/tiff"

* accept="image/x-ms-bmp"

* accept="image/x-photo-cd"

* accept="image/x-png"

* accept="image/x-portablebitmap"

* accept="image/x-portable-greymap"

* accept="image/x-portable-pixmap"

* accept="image/x-rgb"

* accept="text/html"

* accept="text/plain"

* accept="video/quicktime"

* accept="video/x-mpeg2"

* accept="video/x-msvideo"

这个插件还提供了很多的配置参数,对象方法和回调函数。

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

以上就是关于AngularJS文件上传控件的使用方法介绍,希望对大家的学习有所帮助。

Javascript 相关文章推荐
Javascript 构造函数 实例分析
Nov 26 Javascript
可在线编辑网页文字效果代码(单击)
Mar 02 Javascript
js 表单提交后按钮变灰的实例代码
Aug 16 Javascript
JavaScript中的undefined学习总结
Nov 30 Javascript
Javascript实现Web颜色值转换
Feb 05 Javascript
利用Javascript仿Excel的数据透视分析功能
Sep 07 Javascript
KnockoutJS 3.X API 第四章之表单textInput、hasFocus、checked绑定
Oct 11 Javascript
jQuery插件FusionCharts实现的2D柱状图效果示例【附demo源码下载】
Mar 06 Javascript
JavaScript实现简单图片轮播效果
Aug 21 Javascript
使用Ajax和Jquery配合数据库实现下拉框的二级联动的示例
Jan 25 jQuery
微信小程序实现留言板(Storage)
Nov 02 Javascript
解决$store.getters调用不执行的问题
Nov 08 Javascript
JS中call/apply、arguments、undefined/null方法详解
Feb 15 #Javascript
谷歌showModalDialog()方法不兼容出现对话窗口的解决办法
Feb 15 #Javascript
仅30行代码实现Javascript中的MVC
Feb 15 #Javascript
理解javascript中的with关键字
Feb 15 #Javascript
使用基于Node.js的构建工具Grunt来发布ASP.NET MVC项目
Feb 15 #Javascript
JavaScript模版引擎的基本实现方法浅析
Feb 15 #Javascript
在ASP.NET MVC项目中使用RequireJS库的用法示例
Feb 15 #Javascript
You might like
增加反向链接的101个方法 站长推荐
2007/01/31 PHP
PHP6 mysql连接方式说明
2009/02/09 PHP
php 发送带附件邮件示例
2014/01/23 PHP
PHP实现支持CURL字符串证书传输的方法
2019/03/23 PHP
在thinkphp5.0路径中实现去除index.php的方式
2019/10/16 PHP
解决laravel查询构造器中的别名问题
2019/10/17 PHP
FireFox与IE 下js兼容触发click事件的代码
2008/11/20 Javascript
Tinymce+jQuery.Validation使用产生的BUG
2010/03/29 Javascript
一个原生的用户等级的进度条
2010/07/03 Javascript
Jquery图片滚动与幻灯片的实例代码
2013/04/08 Javascript
Javascript实现单例模式
2016/01/24 Javascript
再次谈论Javascript中的this
2016/06/23 Javascript
BootStrap Table对前台页面表格的支持实例讲解
2016/12/22 Javascript
微信小程序 登录实例详解
2017/01/16 Javascript
JavaScript控制输入框中只能输入中文、数字和英文的方法【基于正则实现】
2017/03/03 Javascript
Vue实现路由跳转和嵌套
2017/06/20 Javascript
详解使用vue实现tab 切换操作
2017/07/03 Javascript
Node.js的Koa实现JWT用户认证方法
2018/05/05 Javascript
Vue列表渲染的示例代码
2018/11/01 Javascript
Vue结合后台导入导出Excel问题详解
2019/02/19 Javascript
关于Vue源码vm.$watch()内部原理详解
2019/04/26 Javascript
Vue.js中使用Vuex实现组件数据共享案例
2020/07/31 Javascript
[34:08]2018DOTA2亚洲邀请赛3月29日 小组赛B组 VP VS EG
2018/03/30 DOTA
Windows系统下多版本pip的共存问题详解
2017/10/10 Python
python Spyder界面无法打开的解决方法
2018/04/27 Python
基于Python实现迪杰斯特拉和弗洛伊德算法
2020/05/27 Python
使用Python+wxpy 找出微信里把你删除的好友实例
2019/02/21 Python
学习Django知识点分享
2019/09/11 Python
如何基于python操作json文件获取内容
2019/12/24 Python
Python 剪绳子的多种思路实现(动态规划和贪心)
2020/02/24 Python
Expected conditions模块使用方法汇总代码解析
2020/08/13 Python
大学军训感言200字
2014/02/26 职场文书
《新型玻璃》教学反思
2014/04/13 职场文书
初中生考试作弊检讨书
2014/12/14 职场文书
护理专业自我评价
2015/03/11 职场文书
使用CSS连接数据库的方式
2022/02/28 HTML / CSS