欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Angular下H5上傳圖片的方法(可多張上傳)

 更新時(shí)間:2017年01月09日 13:53:57   作者:秋風(fēng)8  
本文給大家分享在使用angular上傳圖片的功能,在開(kāi)發(fā)過(guò)程中遇到很多問(wèn)題,最終都解決了,今天小編給大家介紹下Angular下H5上傳圖片的方法(可多張上傳),非常不錯(cuò),需要的朋友參考下

最近做的項(xiàng)目中用到了angular下上傳圖片功能,在做的過(guò)程中遇到了許多問(wèn)題,最終都得以解決

angular上傳時(shí)和普通上傳時(shí)過(guò)程差不多,只不過(guò)是要不一些東西轉(zhuǎn)化為angular的東西。

1.ng-file-select,指令angular是沒(méi)此功能的,其實(shí)也是轉(zhuǎn)化成了change事件,不多說(shuō),直接上代碼

angular.module('myApp')
.directive('ngFileSelect', [ '$parse', '$timeout', function($parse, $timeout) {
    return function(scope, elem, attr) {
      var fn = $parse(attr['ngFileSelect']);
      elem.bind('change', function(evt) {
        var files = [], fileList, i;
        fileList = evt.target.files;
        if (fileList != null) {
          for (i = 0; i < fileList.length; i++) {
            files.push(fileList.item(i));
          }
        }
        $timeout(function() {
          fn(scope, {
            $files : files,
            $event : evt
          });
        });
      });
    };
  }])

2.服務(wù) 上傳文件前預(yù)覽并壓縮圖片功能

//上傳文件預(yù)覽
angular.module('myServers',[])
  .factory('fileReader', ['$q', '$log', function($q, $log) {
    var dataURItoBlob = function(dataURI) { 
      // convert base64/URLEncoded data component to raw binary data held in a string 
      var byteString; 
      if (dataURI.split(',')[0].indexOf('base64') >= 0) 
        byteString = atob(dataURI.split(',')[1]); 
      else 
        byteString = unescape(dataURI.split(',')[1]); 
      // separate out the mime component 
      var mimeString = dataURI.split(',')[0].split(':')[1].split(';')[0]; 
      // write the bytes of the string to a typed array 
      var ia = new Uint8Array(byteString.length); 
      for (var i = 0; i < byteString.length; i++) { 
        ia[i] = byteString.charCodeAt(i); 
      } 
      return new Blob([ia], { 
        type: mimeString 
      }); 
    }; 
    var onLoad = function(reader, deferred, scope,file) {
      return function() {
        scope.$apply(function() {
           var img = new Image();
          //前端壓縮圖片
          img.onload = function(){ 
            //resize the image using canvas 
            var canvas = document.createElement("canvas"); 
            var ctx = canvas.getContext("2d"); 
            var width = img.width; 
            var height = img.height; 
            var MAX_WIDTH = width>2500 ? width/2 : 2500; 
            var MAX_HEIGHT = height>2500 ? height/2 : 2500;
            if (width > height) { 
              if (width > MAX_WIDTH) { 
                height *= MAX_WIDTH / width; 
                width = MAX_WIDTH; 
              } 
            } else { 
              if (height > MAX_HEIGHT) { 
                width *= MAX_HEIGHT / height; 
                height = MAX_HEIGHT; 
              } 
            }
            canvas.width = width ; 
            canvas.height = height; 
            ctx.drawImage(img, 0, 0, width, height); 
            var dataURL = canvas.toDataURL('image/jpeg', 1);
            var blob = dataURItoBlob(dataURL); 
            if(blob.size > 2000 * 1024){
              dataURL = canvas.toDataURL('image/jpeg', .2);
            }else if(blob.size > 1000 * 1024){
              dataURL = canvas.toDataURL('image/jpeg', .5);
            }else{
              dataURL = canvas.toDataURL('image/jpeg', .8);
            }
            blob = dataURItoBlob(dataURL);
            deferred.resolve(blob);
          }
          img.src = URL.createObjectURL(file);
        });
      };
    };
    var onError = function(reader, deferred, scope) {
      return function() {
        scope.$apply(function() {
          deferred.reject(reader.result);
        });
      };
    };
    var onProgress = function(reader, scope) {
      return function(event) {
        scope.$broadcast("fileProgress", {
          total: event.total,
          loaded: event.loaded
        });
      };
    };
    var getReader = function(deferred, scope, file) {
      var reader = new FileReader();
      reader.onload = onLoad(reader, deferred, scope,file);
      reader.onerror = onError(reader, deferred, scope);
      reader.onprogress = onProgress(reader, scope);
      return reader;
    };
    var readAsDataURL = function(file, scope) {
      var deferred = $q.defer();
      var reader = getReader(deferred, scope,file);
      reader.readAsDataURL(file);
      return deferred.promise;
    };
    return {
      readAsDataUrl: readAsDataURL
    };
  }]);

這里說(shuō)明一下,部分代碼是參考別人的代碼(http://blog.csdn.net/zx007fack/article/details/41073601),但是對(duì)其中內(nèi)容做了修改,因?yàn)橛迷瓉?lái)的代碼,如果不加前端壓縮功能是正常的,前端壓縮的話(huà)因?yàn)橐玫絚anvas, 直接用reader.result在ios上圖片的寬高拿到的直接是0,android上是可以的,具體原因不是很確定是不是base64的問(wèn)題,所以我又直接把file傳了進(jìn)來(lái),然后用原生js的方法新建圖片元素拿到寬高,再用Canvas進(jìn)行壓縮,最后轉(zhuǎn)成blob,通過(guò)formData傳給后臺(tái)。

3.controller代碼

//選擇圖片后執(zhí)行的方法
    $scope.fileArr = [];
    $scope.imgSrcArr = [];var i = 0; //為ios上圖片都為image時(shí)添加序號(hào)
    $rootScope.onFileSelect = function(files, event) {
      //預(yù)覽上傳圖片開(kāi)始
      $rootScope.startLoading();
      var $this = angular.element(event.target);
      angular.forEach(files, function(value, index) {
        var fileIn = value;
        var fileInName = fileIn.name;
        var fileType = fileInName.substring(fileInName.lastIndexOf(".") + 1, fileInName.length);
        //解決ios下所有圖片都為image.jpg的bug
        if(fileIn) {
          fileInName = fileInName.split('.')[0] + i + '.' + fileType;
          i++;
        }
        attachvo.push({
          name: fileInName,
          type: fileType
        });
        fileReader.readAsDataUrl(fileIn, $scope)
          .then(function(result) {
            result.name = fileInName;
            $scope.fileArr.push(result);
            $scope.imgSrcArr.push(URL.createObjectURL(result));
              //每次上傳后清空f(shuō)ile框,確保每次都能調(diào)用change事件
            document.querySelector('.upload').reset();
          });
        $scope.$on('fileProgress', function(event, data) {
          if(data.total == data.loaded) {
            $timeout(function() {
              //上傳圖片結(jié)束
              $rootScope.endLoading();
            }, 200)
          }
        });      
      });
      $rootScope.showAttachment = false;
    };return false;
    }

這里處理了下圖片,在名字上加了序號(hào),因?yàn)樵趇os上每次選擇的圖片名字都叫image,查找了很多資料,說(shuō)是safari的bug,后面版本才會(huì)解決,暫時(shí)只能以這種方式解決了。循環(huán)是上傳多張圖片

3.html代碼

<ul class="upload-view-ul">
    <li ng-repeat="src in imgSrcArr" class="pull-left" ng-click="delCurUpload(src)" 
      ng-class="{'row-last': (($index+1) % 5==0)}">
      <span>x</span>
      <em ng-if='nrc'>{{formData.attachvo[$index].attachmentType}}</em>
      <img ng-src="{{src}}">
    </li>
    <div class="attachment" pop-type-select ng-if="nrc">+</div>
    <div class="attachment" ng-if="!nrc">
      +
      <form class="upload">
        <input type="file" name="file[]" ng-file-select="onFileSelect($files, $event)" multiple>
      </form>
    </div>
  </ul>

4.順便把formdata時(shí)代碼貼一下,采用H5上傳圖片的方式

this.FormdataPost = function(pathUrl, formId, formData, files) {
    var fd = new FormData();
    fd.append('formId', formId);
    if(files && angular.isArray(files)) {
      files.forEach(function(item) {
        fd.append('file', item, item.name);
      });
    }
    fd.append('formData', angular.toJson(formData, true));
    var httpConfig = {
      headers: {
        'Authorization': 'Bearer ' + this.token,
        'Content-Type': undefined
      },
      transformRequest: angular.identity
    };
    return $http.post(rootUrl + pathUrl, fd, httpConfig).then(function(data) {
      return data;
    }).catch(function(error) {
      $rootScope.interfaceName = pathUrl;
      $rootScope.setNewWortStatus({
        status: error.status,
        errInfo: error.data && error.data.statusInfo || ''
      });
      return error;
    });
  }

思路有一點(diǎn)混亂,不知道講清楚了沒(méi)有,想起來(lái)再添加吧

以上所述是小編給大家介紹的Angular下H5上傳圖片的方法(可多張上傳),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • AngularJS ng-repeat數(shù)組有重復(fù)值的解決方法

    AngularJS ng-repeat數(shù)組有重復(fù)值的解決方法

    不知道大家是否遇到過(guò)這個(gè)問(wèn)題,在當(dāng)Angular.JS ng-repeat數(shù)組中有重復(fù)項(xiàng)時(shí),系統(tǒng)就會(huì)拋出異常,這是該怎么做?本文通過(guò)示例代碼介紹了詳細(xì)的解決方法,有需要的朋友們可以參考借鑒,下面來(lái)一起看看吧。
    2016-10-10
  • AngularJS下$http服務(wù)Post方法傳遞json參數(shù)的實(shí)例

    AngularJS下$http服務(wù)Post方法傳遞json參數(shù)的實(shí)例

    下面小編就為大家分享一篇AngularJS下$http服務(wù)Post方法傳遞json參數(shù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • AngularJS指令與指令之間的交互功能示例

    AngularJS指令與指令之間的交互功能示例

    這篇文章主要介紹了AngularJS指令與指令之間的交互功能,結(jié)合實(shí)例形式分析了AngularJS指令交互操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2016-12-12
  • Angular組件間通信的新解決方案詳解

    Angular組件間通信的新解決方案詳解

    本文通過(guò)對(duì)比幾種Angular組件間的通信方式,給大家介紹了一種新的Angular組件間通信的解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • MODULE_INITIALIZER初始化Angular?懶加載模塊高級(jí)技巧

    MODULE_INITIALIZER初始化Angular?懶加載模塊高級(jí)技巧

    這篇文章主要為大家介紹了MODULE_INITIALIZER初始化Angular懶加載模塊高級(jí)技巧示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • Angular4學(xué)習(xí)筆記router的簡(jiǎn)單使用

    Angular4學(xué)習(xí)筆記router的簡(jiǎn)單使用

    本篇文章主要介紹了Angular4學(xué)習(xí)筆記router的簡(jiǎn)單使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • 解決Angular2 router.navigate刷新頁(yè)面的問(wèn)題

    解決Angular2 router.navigate刷新頁(yè)面的問(wèn)題

    今天小編就為大家分享一篇解決Angular2 router.navigate刷新頁(yè)面的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-08-08
  • 詳解AngularJS中的表格使用

    詳解AngularJS中的表格使用

    這篇文章主要介紹了詳解AngularJS中的表格使用,作為熱門(mén)的JavaScript框架,AngularJS中提供的表格功能十分強(qiáng)大,需要的朋友可以參考下
    2015-06-06
  • 詳解AngularJS中$http緩存以及處理多個(gè)$http請(qǐng)求的方法

    詳解AngularJS中$http緩存以及處理多個(gè)$http請(qǐng)求的方法

    $http 是 AngularJS 中的一個(gè)核心服務(wù),用于讀取遠(yuǎn)程服務(wù)器的數(shù)據(jù),通過(guò)本文給大家介紹AngularJS中$http緩存以及處理多個(gè)$http請(qǐng)求的方法,希望的朋友一起學(xué)習(xí)吧
    2016-02-02
  • Angular中的請(qǐng)求攔截的方法

    Angular中的請(qǐng)求攔截的方法

    我們的接口是單獨(dú)編寫(xiě)的處理的,在實(shí)際的開(kāi)發(fā)項(xiàng)目中,有眾多的接口,有些需要登陸憑證,有些不需要。一個(gè)一個(gè)接口處理不妥,我們是否可以考慮對(duì)請(qǐng)求進(jìn)行攔截封裝,感興趣的可以了解一下
    2022-04-04

最新評(píng)論