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

AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法分析

 更新時(shí)間:2017年11月08日 11:46:34   作者:目盡地平線  
這篇文章主要介紹了AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法,結(jié)合HTML5實(shí)例形式對(duì)比分析了AngularJS圖片上傳的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法。分享給大家供大家參考,具體如下:

html5原生方法

先看一下html5原生方法上傳和預(yù)覽圖片的實(shí)現(xiàn):

// <img id="img-preview">
var imgPreview = document.getElementById("img-preview");
// <input id="img-input" type="file">
var imgInput= document.getElementById("img-input");
imgInput.addEventListener("change", function(e){
 var imgFile = e.target.files[0]; // 獲取上傳的圖片
 var reader = new FileReader();
 reader.readAsDataURL(imgFile ); // 將圖片轉(zhuǎn)成dataUri
 reader.onload = function(e) {
  imgPreview.src = e.target.result; //更新圖片鏈接
 }
});

我們看到,需要用到onchange事件來獲得上傳的文件,當(dāng)項(xiàng)目使用上angularjs時(shí),很自然的,我們想到了ng-change指令,然而不幸的是,在angularjs中,<input type="file">不支持ng-model和ng-change指令(附錄1),這就使得文件上傳變得有些復(fù)雜了。

angularjs方法

這里使用開源的 angular-file-upload 模塊來實(shí)現(xiàn),步驟如下:

1、安裝 angular-file-upload 模塊

bower install angular-file-upload --save

2、添加到應(yīng)用依賴

var app = angular.module('my-app', [
  'angularFileUpload'
]);

3、HTML代碼

<!--文件上傳指令-->
<input type="file" nv-file-select="" uploader="uploader" />
<!--圖片預(yù)覽-->
<img id="img-preview" ng-src="{{iconUrl}}">

這里,nv-file-select=""表示使用angular-file-upload模塊的文件選擇方式上傳,參考官方例子

4、controller代碼

.controller('AppController', ['$scope', 'FileUploader', function($scope, FileUploader) {
    var uploader = $scope.uploader = new FileUploader({
      url: 'upload.php' //換成自己的上傳地址,本地演示不換也行
    });
    uploader.onAfterAddingFile = function(fileItem) {
      var reader = new FileReader();
      reader.addEventListener("load", function (e) {
        //文件加載完之后,更新angular綁定
        $scope.$apply(function(){
          $scope.iconUrl = e.target.result;
        });
      }, false);
      reader.readAsDataURL(fileItem._file);
    };
}]);

可以看到,我們通過onAfterAddingFile回調(diào)函數(shù)獲得所選的圖片文件,接下來把圖片文件轉(zhuǎn)成datauri,再更新<img>標(biāo)簽的src屬性即可。

值得注意的是,我們把“更新<img>標(biāo)簽的src屬性”這個(gè)任務(wù)放到了$scope.$apply方法中執(zhí)行,這是因?yàn)樵赼ngular框架外部(如在瀏覽器DOM事件中, setTimeout, XHR 或者 第三方框架中)更新數(shù)據(jù),angular是不會(huì)同步更新綁定的。這點(diǎn)可以參考angular $apply reference

更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)

希望本文所述對(duì)大家AngularJS程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論