Angularjs上传图片实例详解


Posted in Javascript onAugust 06, 2017

•上传图片需要引入插件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上传图片实例详解,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

Javascript 相关文章推荐
浅谈Javascript面向对象编程
Nov 15 Javascript
jquery操作下拉列表、文本框、复选框、单选框集合(收藏)
Jan 08 Javascript
JavaScript实现动态删除列表框值的方法
Aug 12 Javascript
jQuery Easyui datagrid/treegrid 清空数据
Jul 09 Javascript
vue.js入门教程之基础语法小结
Sep 01 Javascript
vue2.0在table中实现全选和反选的示例代码
Nov 04 Javascript
详解Angular调试技巧之报错404(not found)
Jan 31 Javascript
通过vue-cli3构建一个SSR应用程序的方法
Sep 13 Javascript
vue项目中实现的微信分享功能示例
Jan 21 Javascript
js设计模式之单例模式原理与用法详解
Aug 15 Javascript
Vue中登录验证成功后保存token,并每次请求携带并验证token操作
Sep 08 Javascript
OpenLayers3加载常用控件使用方法详解
Sep 25 Javascript
微信小程序 自定义消息提示框
Aug 06 #Javascript
最通俗易懂的javascript变量提升详解
Aug 05 #Javascript
Vue2.0 vue-source jsonp 跨域请求
Aug 04 #Javascript
js分页之前端代码实现和请求处理
Aug 04 #Javascript
微信小程序 rich-text的使用方法
Aug 04 #Javascript
Easyui和zTree两种方式分别实现树形下拉框
Aug 04 #Javascript
JS中使用media实现响应式布局
Aug 04 #Javascript
You might like
jQuery EasyUI中对表格进行编辑的实现代码
2010/06/10 Javascript
javascript中的undefined和not defined区别示例介绍
2014/02/26 Javascript
node.js中的require使用详解
2014/12/15 Javascript
浅析JavaScript Array和string的转换(推荐)
2016/05/20 Javascript
es6 字符串String的扩展(实例讲解)
2017/08/03 Javascript
基于jQuery Ajax实现下拉框无刷新联动
2017/12/06 jQuery
vue-router3.0版本中 router.push 不能刷新页面的问题
2018/05/10 Javascript
小程序图片剪裁加旋转的示例代码
2018/07/10 Javascript
让axios发送表单请求形式的键值对post数据的实例
2018/08/11 Javascript
浅析vue给不同环境配置不同打包命令
2018/08/17 Javascript
VUE基于NUXT的SSR 服务端渲染
2018/11/30 Javascript
vue-for循环嵌套操作示例
2019/01/28 Javascript
JS中min函数实例讲解
2019/02/18 Javascript
Vue+scss白天和夜间模式切换功能的实现方法
2021/01/05 Vue.js
[13:18]《一刀刀一天》之DOTA全时刻21:详解TI新赛制 A队再露獠牙
2014/06/24 DOTA
python将html转成PDF的实现代码(包含中文)
2013/03/04 Python
python错误:AttributeError: 'module' object has no attribute 'setdefaultencoding'问题的解决方法
2014/08/22 Python
python连接字符串的方法小结
2015/07/13 Python
举例讲解Python中的Null模式与桥接模式编程
2016/02/02 Python
浅析Python与Mongodb数据库之间的操作方法
2019/07/01 Python
Python换行与不换行的输出实例
2020/02/19 Python
使用pygame编写Flappy bird小游戏
2020/03/14 Python
Python Selenium安装及环境配置的实现
2020/03/17 Python
详解基于Jupyter notebooks采用sklearn库实现多元回归方程编程
2020/03/25 Python
详解python变量与数据类型
2020/08/25 Python
通过Django Admin+HttpRunner1.5.6实现简易接口测试平台
2020/11/11 Python
CSS3颜色值RGBA与渐变色使用介绍
2020/03/06 HTML / CSS
美国畅销的跑步机品牌:ProForm
2017/02/06 全球购物
遗嘱继承公证书
2014/04/09 职场文书
目标责任书范文
2014/04/14 职场文书
项目合作协议书
2014/04/16 职场文书
治庸问责心得体会
2014/09/12 职场文书
医院志愿者活动总结
2015/05/06 职场文书
2016护理专业求职自荐书
2016/01/28 职场文书
学习型家庭事迹材料(2016精选版)
2016/02/29 职场文书
python井字棋游戏实现人机对战
2022/04/28 Python