angular js 上传插件 ng-file-upload 使用时注意事项

项目框架为angular js,须要用到文件上传,百度以后先选择了angular-file-upload,githuab上API文档很全,想要具体了解,能够仔细研究一下。在这里简单回顾一下本身使用的插件的部分功能和须要注意的事项。javascript

1.引入angular-file-upload.js,放在angular js 以后。java

2.将文件注入angular js 的模块中,如 var app =  angular.module (" myapp ", [ ' angularFileUpload ' ]  );git

3.下面就是具体使用了,API文档中 介绍的很详细,支持多种上传样式,如单选,多选,单击选择,拖拽选择等。能够具体研究。我只用到了单选同时也是单击选择。app

<div    ng-app="myapp">框架

<div ng-controller="appCtrl">函数

<input  type="file" nv-file-select  uploader = "uploader">url

<ul>spa

<li  ng-repeat="item in uploader.queue">插件

    <span>{{item.file.name}}</span>orm

</li>

</ul>

</div>

</div>

其中input file 为上传按钮,它自己的样式比较简单,我这里只须要一个上传按钮,只能用a标签包住input,并将input 设为透明,来实现我想要的按钮样式。

li标签repeat 出来的就是上传后的文件。queue就是上传后的队列。固然我这里每一个文件后还提供删除按钮,这样用他的队列就不太好改,我也尝试过。最终决定本身作个repeat 把上传后的文件名显示在页面上,同时提供删除方法。

4.js中有许多属性,方法和回调函数。具体能够研究API.

controller中一样须要注入。例

myapp.contrller("appCtrl",function(FileUploader){

var uploader = $scope.uploader = new FileUploader({

url:""    //上传文件的url

formData:[Array]   //跟随上传文件同时上传的参数。[{}]参数

autoUpload:true   //自动上传

})

})

alias 里面的名称须要与后台代码中的一致,默认为file.

回调函数有成功后,添加后失败后执行的操做,再也不一一赘述。

说了半天,重点来了,插件的兼容性如何,原本加上列出的shim.js等等,觉得会兼容,但在IE9上始终上传失败,报错。

typeErr.最终没办法只好再换一个插件即ng-file-upload.先说一下这个插件的兼容性。

它是能够兼容到IE9,对于IE9及一下,能够引入shim.js和一段

 <!--[if lte IE 9]> 

 <script>
    FileAPI = {
        jsUrl: 'FileAPI.min.js',
        flashUrl: 'FileAPI.flash.swf',
   
    }
</script>
<script src="ng-file-upload-shim.js" type="text/javascript" charset="utf-8"></script>
<![endif]-->

注意这段须要放在shim.js 前面,同时 包含FileAPI.min.js和FileAPI.flash.swf这两个文件。

具体使用和angular-file-upload,类似,就是所用文件和格式不一样。详细能够研究API文档,再也不赘述。

相关文章
相关标签/搜索