二、angularjs上传图片

  • 上传图片需要引入插件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;
            }
时间: 2024-08-14 22:20:52

二、angularjs上传图片的相关文章

【原创】.Net 微信 JS-SDK图片、语音上传接口的实现(MVC)-(二 、上传图片服务器操作)

上一篇文章,已经介绍过关于微信上传图片的前端JS-SDK , 如果有没看到第一篇的朋友, 可以先看看第一篇 http://www.cnblogs.com/29boke/p/5483599.html 好了,现在继续向大家介绍,我们.NET 是如何实现图片上传到自己的服务器的. 上次提到, function upload() {             wx.uploadImage({                 localId: images.localId[i],              

angularjs上传图片

通过AngularJS实现图片上传及缩略图展示 AngularJS图片上传功能的实现

篇章二:[AngularJS] 使用AngularAMD動態載入Service

前言 「使用AngularAMD動態載入Controller」:這篇文章裡介紹如何使用AngularAMD來動態載入Controller.本篇文章以此為基礎,介紹如何使用AngularAMD來動態載入Service,讓SPA的啟動過程更加輕量化,用以提升使用者的操作體驗.並且也透過這樣掛載式的設計,讓專案功能更加模組化,增加開發與維護的工作效率.主要為自己留個紀錄,也希望能幫助到有需要的開發人員. AngularAMD 安裝 本篇文章以「使用AngularAMD動態載入Controller」的範

angularjs上传图片和文件

很简单: $scope.upload = function() { var f = $scope.myFile; var fd = new FormData(); var img = document.querySelector('input[type=file]').files[0]; //var file = []; //file.push(f); // file.push(img); fd.append('issueId', '1'); fd.append('file', img); $h

angularJS(3)

angularJS(3) 一.angularJs的指令模型ng-model指令 ng-model 指令 绑定 HTML 元素 到应用程序数据. 为应用程序数据提供类型验证(number.email.required).为应用程序数据提供状态.为 HTML 元素提供 CSS 类.绑定 HTML 元素到 HTML 表单. <div ng-app="myapp" ng-controller="mycc"> 名字: <input ng-model=&quo

AngularJs之三

一.angularJs的指令模型ng-model指令 ng-model 指令 绑定 HTML 元素 到应用程序数据. 为应用程序数据提供类型验证(number.email.required).为应用程序数据提供状态.为 HTML 元素提供 CSS 类.绑定 HTML 元素到 HTML 表单. <div ng-app="myapp" ng-controller="mycc"> 名字: <input ng-model="name"&

angularJs $injector

一 angularJS中几种注入方式 Spring中使用构造注入或者设值注入的方式,还需要做一些额外的操作,但是angular中只需要在需要的地方声明一下即可,类似模块的引用,因此十分方便. angularJS中有几种注入方式: 推断式注入:这种注入方式,需要在保证参数名称与服务名称相同.如果代码要经过压缩等操作,就会导致注入失败. <div ng-controller="myCtrl1"> <input type="button" ng-clic

跟我从0开始学angularjs-笔记01

一.angularjs简介 AngularJS 是一个为动态WEB应用设计的结构框架.它能让你使用HTML作为模板语言,通过扩展HTML的语法,让你能更清楚.简洁地构建你的应用组件.它的创新点在于,利用 数据绑定 和 依赖注入,它使你不用再写大量的代码了.这些全都是通过浏览器端的Javascript实现,这也使得它能够完美地和任何服务器端技术结合. 说了这么多,估计你啥都没有理解...对吗?别着急,我来说说他的几个特点吧:模块化,数据双向绑定,依赖注入,指令.下面我们就跟着这几个特点进行学习.

上传图片-AFN

上传图片分为两种 :一种是只上传图片,一种是即上传图片又上传文字. 一.只上传图片,代码如下 - (void)httpRequestUploadMeHeadImageWithFile:(UIImage *)file UUID:(NSString *)UUID error:(void (^)(NSError *))err{ NSString *url = [NSString stringWithFormat:@"%@图片上传地址"]; NSDictionary *parametes; i