三、angularjs上传图片

本文介绍如何在Angular应用中使用ngFileUpload插件进行图片上传。通过bower安装插件,注入到模块,并在HTML中使用ngf-select指令。文章详细展示了上传功能的实现,包括设置文件类型限制、大小限制以及错误处理。
摘要由CSDN通过智能技术生成
  • 上传图片需要引入插件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;
            }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值