首页 > 编程 > JavaScript > 正文

Angularjs上传图片实例详解

2019-11-19 15:53:49
字体:
来源:转载
供稿:网友

•上传图片需要引入插件ngFileUpload,使用bower安装方法: bower install ng-file-upload --save,安装后需要在命名app的名字js文件中注入,如下所示:

(function() {  angular.module('app', [    'ionic','ngStorage','ngFileUpload'  ]);})();

•在相应的html中引入文件路径:<script src="lib/ng-file-upload/ng-file-upload.min.js"></script>

•如何使用呢?在html文件中使用 ngf-select

<div class="editHeader_div" ngf-select="setStore.uploadFiles($file, $invalidFiles)">        <img class="editStoreImg" ng-src="img/{{setStore.img}}">        <p>更改头像</p> </div>

在相应的controller中:

 //上传单个文件    function uploadFiles(file, errFiles) {      vm.imgInfo = file;      console.log(file);      if (file) {        vm.img = file.name;//测试使用        //Service.upload('','',{file:file})//开发使用      }    }

在http请求如下:

 //文件上传预设配置      Upload.setDefaults({        ngfAccept: "'.jpg,.png,.gif,.jpeg'",        ngfDropDisabled: 'true',        ngfPattern: '.jpg,.png,.gif,.jpeg',        ngfMaxSize: '2MB'      }); //上传文件      function upload(ctrl, name, param) {        var deferred = $q.defer(),          interfaceName = ctrl + '/' + name,          backendDetail = getBackendDetail(interfaceName);        //上传文件到服务器        Upload.upload({          url: backend.url + ':' + backendDetail.port + '/' + backendDetail.service + '/' + interfaceName,          data: param || {}        }).then(function(data) {          //service返回数据          var result = data.data;          //200代表接口调用成功          if (data.status === 200) {            //数据库返回错误信息            if (result && serviceErrors[result.returnCode]) {              deferred.reject('Error Services');              swal(result.message, '错误状态码:' + result.returnCode, 'error');            } else if (!result.dataInfo) {              deferred.reject('Error Image');              swal('图片上传失败', '请检查图片属性', 'error');            } else {              deferred.resolve(result);            }          } else {            deferred.reject('Error Services');            swal('提交操作失败', '错误状态码:' + data.status, 'error');          }        }, function(error) {          deferred.reject('Error Services');          swal('提交操作失败', '错误状态码:' + error.status, 'error');        });        return deferred.promise;      }

总结

以上所述是小编给大家介绍的Angularjs上传图片实例详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表