亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

Angularjs實現多圖片上傳預覽功能

2019-11-19 13:27:57
字體:
來源:轉載
供稿:網友

最近要實現一個多圖片上傳的預覽功能,網上有很多例子大多不太完整,我就把他們的整合了下并且加了一些功能和界面,我們只需要調用一條指令就可以實現,但傳給后臺還需要額外的代碼,會在后面controller里介紹。不知道封裝的是否符合標準,還希望大家一起討論下,如果有時間封裝下Angular4的圖片上傳和預覽分享給大家。

圖片上傳的預覽,我們最主要解決的是拿到input的on-change事件,再是讀取圖片,讀取圖片我們需要用到FileReader。

我們先寫一個讀取圖片的服務,這是網上的一位大佬寫的,我就直接拿了過來

/** * 圖片上傳獲取返回的url */      app .factory('fileReader', ["$q", "$log", function($q, $log){        var onLoad = function(reader, deferred, scope) {          return function () {            scope.$apply(function () {              deferred.resolve(reader.result);            });          };        };        var onError = function (reader, deferred, scope) {          return function () {            scope.$apply(function () {              deferred.reject(reader.result);            });          };        };        var getReader = function(deferred, scope) {          var reader = new FileReader(); //fileReader          reader.onload = onLoad(reader, deferred, scope);          reader.onerror = onError(reader, deferred, scope);          return reader;        };        var readAsDataURL = function (file, scope) {          var deferred = $q.defer();          var reader = getReader(deferred, scope);             reader.readAsDataURL(file);            return deferred.promise;        };        return {          readAsDataUrl: readAsDataURL       };}])

我們現在有了圖片的讀取,我們再來搞定圖片的on-change事件

/** * 圖片上傳預覽 */app .directive('file', ['$parse', 'fileReader', function ($parse, fileReader) {       return {        restrict: 'A',        link: function(scope, element, attrs, ngModel) {          var model = $parse(attrs.file);          var modelSetter = model.assign;          console.log(modelSetter)          element.bind('change', function(event){            scope.$apply(function(){              modelSetter(scope, element[0].files[0]);            });            //附件預覽                        scope.imgupload = (event.srcElement || event.target).files[0];               getFile(scope.imgupload, scope);              //獲得預覽圖地址并且把file對象放入上傳合集內               function getFile (imgupload, scope) {                 if(!imgupload) {                   return;                 }                 fileReader.readAsDataUrl(imgupload, scope)                        .then(function(result) {                         scope.imgshows.push(result)                         var file = document.querySelector('input[type=file]').files[0];                         scope.uploadimgs.push(file)//這里是放著傳給后臺的數據file,下面controller的時候會有                        });               };          });        }      };    }]) 

這里就是提供上傳圖片預覽的樣式,還有預覽圖刪除的功能

app .directive('uploadimg', function () {       return {        restrict: 'E',         scope: {          uploadimgs: "="        },        templateUrl: './js/directives/uploadimg/uploadimg.html',              link: function(scope, element, attrs) {            scope.imgshows = []//預覽圖片合集放的是src                scope.uploadimg_del = function(index,imgs) {                  scope.imgshows.splice(index,1);                scope.uploadimgs.splice(index,1);      }     } }}) 

<style type="text/css">.fileupload {  width: 100px;  height: 100px;  border: 1px dotted #ccc;  display: inline-block;}.fileupload-icon {  font-size:32px;  position: absolute;  top: 50%;  left: 50%;  transform: translate(-50%,-50%);}</style><div>  <div class="fileupload pos-rlt" ng-repeat="imageSrc in imgshows">    <img ng-src="{{imageSrc}}" style="max-width:200px;max-height:300px;margin:0 auto; display:block;" class="pos-rlt" width=100%; height=100%;/>    <i class="icon ion-close-circled" style="position: absolute; top:5px; right: 5px" ng-click="uploadimg_del($index, imgshows)"></i>  </div>  <div class="fileupload pos-rlt clear" >    <i class="icon ion-plus-round fileupload-icon"></i>    <input type="file" style="display:inline-block; width: 100%; height: 100%; opacity:0" name="upload_img" file="upload_img" placeholder="選擇圖片" accept="image/png,image/gif,image/jpeg,image/jpg"  >  </div></div></label>

最后的調用也很簡單
我們只需要在2個地方加代碼一個是在界面,一個是在Controller里

<uploadimg uploadimgs="uploadimgs"></uploadimg>

這個是在Controller里的,這是用來傳給后臺的數據集合,我們需要傳給后臺的是file對象

$scope.uploadimgs = []//上傳圖片合集放的是file對象

如何傳給后臺呢,直接附上代碼,其實不難

$scope.save = function() {         var Fromdata = {      'name': $scope.form.name,      'desc': $scope.form.descr,      'price': $scope.form.price,      'status': $scope.form.status?1:0,    }    var uploadData = createFromData(Fromdata)    for(var i = 0; i < $scope.uploadimgs.length; i++) {      uploadData.append('upload_imgs', $scope.uploadimgs[i])    }     $http({     method:'POST',     url:"后臺地址",     data: fd,     headers: {'Content-Type':undefined},     transformRequest: angular.identity     })     .success( function(response){     //上傳成功的操作     });   }  //構造FormData//@param 是一個對象function createFromData(Fromdata) {   var fd = new FormData();   for(key in Fromdata) {     fd.append(key,Fromdata[key]);    }   return fd}

最后給大家看下預覽圖

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
精品日韩中文字幕| 成人性教育视频在线观看| 日本不卡高字幕在线2019| 狠狠躁天天躁日日躁欧美| 欧美日韩国产一区二区三区| 色综合伊人色综合网站| 黑人与娇小精品av专区| 国产成人免费91av在线| www.欧美精品一二三区| 日韩欧美极品在线观看| 久久久久99精品久久久久| 亚洲自拍偷拍色片视频| 国产裸体写真av一区二区| 欧美老女人在线视频| 亚洲自拍高清视频网站| 97免费视频在线| 欧美成在线观看| 91po在线观看91精品国产性色| 在线亚洲午夜片av大片| 中文综合在线观看| 97人人模人人爽人人喊中文字| 精品成人av一区| 欧美日韩免费观看中文| 欧美特黄级在线| 国产精品久久久久99| 美女扒开尿口让男人操亚洲视频网站| 在线日韩中文字幕| 中文字幕一精品亚洲无线一区| 国外成人在线视频| 日韩欧美国产黄色| 九九热99久久久国产盗摄| 欧美另类老女人| 久久影视三级福利片| 亚洲精品一区二区在线| 麻豆国产精品va在线观看不卡| 久久精品99久久久香蕉| 91久久久精品| www.欧美精品一二三区| 奇门遁甲1982国语版免费观看高清| 中文字幕亚洲图片| 2019中文字幕在线免费观看| 成人亲热视频网站| 欧美视频国产精品| 91精品国产99久久久久久| 亚洲天堂av图片| 国产日韩欧美成人| 日韩成人中文字幕| 超碰精品一区二区三区乱码| 欧美刺激性大交免费视频| 91免费精品国偷自产在线| 久久久久亚洲精品| 国产成人综合一区二区三区| 国产日产欧美a一级在线| 韩日精品中文字幕| 日韩av电影手机在线观看| 97精品久久久中文字幕免费| 欧美综合在线第二页| 亚洲91精品在线| 国产精品一区二区久久久| 人人澡人人澡人人看欧美| 91chinesevideo永久地址| 国产精品高潮呻吟久久av无限| 国产精品白嫩美女在线观看| 亚洲黄色www| 亚洲美女av网站| 丁香五六月婷婷久久激情| 欧美在线一区二区视频| 欧美激情中文字幕乱码免费| 久久久久久国产三级电影| 国产精品久久久久久久久久久久久| 亚洲午夜性刺激影院| 日韩国产中文字幕| 国产91精品高潮白浆喷水| 97在线精品国自产拍中文| 在线成人激情视频| 欧美在线性视频| 久久精品成人一区二区三区| 俺去啦;欧美日韩| 色综合五月天导航| 在线精品视频视频中文字幕| 欧美成aaa人片在线观看蜜臀| 亚洲免费av片| 亚洲免费视频观看| 久久不射热爱视频精品| 日韩在线观看你懂的| 亚洲欧洲午夜一线一品| 日韩在线中文字幕| www.国产一区| 91久久综合亚洲鲁鲁五月天| 欧美一级黄色网| 成人深夜直播免费观看| 91免费精品国偷自产在线| 欧美男插女视频| 色www亚洲国产张柏芝| 亚洲精品美女久久| 日本91av在线播放| 亚洲欧美精品中文字幕在线| 亚洲精品一区久久久久久| 日韩中文字幕在线视频播放| 国产中文字幕亚洲| 日韩中文字幕在线视频播放| 亚洲最大福利视频网| 亚洲第一区中文字幕| 国产亚洲欧洲在线| 91精品视频大全| 日韩av在线免费观看| 久久香蕉国产线看观看网| 欧美影院久久久| 欧美日韩成人在线观看| 亚洲片av在线| 韩国福利视频一区| 亚洲精品动漫久久久久| 黑人巨大精品欧美一区免费视频| 亚洲japanese制服美女| 国语自产在线不卡| 亚洲电影av在线| 亚洲欧洲在线视频| 91九色国产在线| 中文字幕欧美视频在线| 欧美乱大交xxxxx| 欧美黑人性视频| 国产精品电影观看| 97在线视频免费看| 色悠悠国产精品| 亚洲成**性毛茸茸| 国产中文字幕日韩| 91精品久久久久久久久久入口| 深夜精品寂寞黄网站在线观看| 国产精品一区二区av影院萌芽| 欧美日韩一区二区三区在线免费观看| 日韩小视频网址| 一区二区欧美日韩视频| 国产精品免费网站| 91久久精品美女高潮| 日本久久亚洲电影| 国产亚洲精品va在线观看| 亚洲女同性videos| 成人性生交xxxxx网站| 国产成人在线播放| 欧美视频第一页| 韩剧1988免费观看全集| 日韩欧美一区二区三区久久| 美女av一区二区| 欧美电影免费观看网站| 亚洲丁香久久久| 国产精品亚洲精品| 日韩亚洲精品视频| 欧美电影免费观看| 一区二区三区亚洲| 亚洲加勒比久久88色综合| 日韩欧美国产激情| 深夜精品寂寞黄网站在线观看| 91亚洲精品一区二区| 日韩在线视频观看| 欧美成人精品xxx| 国产一区二中文字幕在线看| 国产一区深夜福利| 国产偷国产偷亚洲清高网站| 色综合亚洲精品激情狠狠| 欧美亚洲在线观看| 国产69精品久久久久久| 日韩精品免费在线视频观看| 欧美国产日产韩国视频| 亚洲一区二区三区久久|