欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Angularjs上传图片实例详解

程序员文章站 2022-04-29 08:04:08
•上传图片需要引入插件ngfileupload,使用bower安装方法: bower install ng-file-upload --save,安装后需要在命...

•上传图片需要引入插件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上传图片实例详解,希望对大家有所帮助