AngularJS實現(xiàn)圖片上傳和預覽功能的方法分析
本文實例講述了AngularJS實現(xiàn)圖片上傳和預覽功能的方法。分享給大家供大家參考,具體如下:
html5原生方法
先看一下html5原生方法上傳和預覽圖片的實現(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 ); // 將圖片轉成dataUri
reader.onload = function(e) {
imgPreview.src = e.target.result; //更新圖片鏈接
}
});
我們看到,需要用到onchange事件來獲得上傳的文件,當項目使用上angularjs時,很自然的,我們想到了ng-change指令,然而不幸的是,在angularjs中,<input type="file">不支持ng-model和ng-change指令(附錄1),這就使得文件上傳變得有些復雜了。
angularjs方法
這里使用開源的 angular-file-upload 模塊來實現(xiàn),步驟如下:
1、安裝 angular-file-upload 模塊
bower install angular-file-upload --save
2、添加到應用依賴
var app = angular.module('my-app', [
'angularFileUpload'
]);
3、HTML代碼
<!--文件上傳指令-->
<input type="file" nv-file-select="" uploader="uploader" />
<!--圖片預覽-->
<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回調函數(shù)獲得所選的圖片文件,接下來把圖片文件轉成datauri,再更新<img>標簽的src屬性即可。
值得注意的是,我們把“更新<img>標簽的src屬性”這個任務放到了$scope.$apply方法中執(zhí)行,這是因為在angular框架外部(如在瀏覽器DOM事件中, setTimeout, XHR 或者 第三方框架中)更新數(shù)據(jù),angular是不會同步更新綁定的。這點可以參考angular $apply reference
更多關于AngularJS相關內容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結》、《AngularJS入門與進階教程》及《AngularJS MVC架構總結》
希望本文所述對大家AngularJS程序設計有所幫助。
相關文章
AngularJS入門教程之 XMLHttpRequest實例講解
本文主要講解 AngularJS XMLHttpRequest,這里給大家整理相關資料并提供實例代碼,有需要的小伙伴參考下2016-07-07
AngularJs用戶輸入動態(tài)模板XSS攻擊示例詳解
這篇文章主要給大家介紹了關于AngularJs用戶輸入動態(tài)模板XSS攻擊的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用angularjs具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2018-04-04
AngularJs的UI組件ui-Bootstrap之Tooltip和Popover
這篇文章主要介紹了AngularJs的UI組件ui-Bootstrap之Tooltip和Popover,tooltip和popover是輕量的、可擴展的、用于提示的指令。具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07
angular框架實現(xiàn)全選與單選chekbox的自定義
這篇文章主要介紹了angular框架實現(xiàn)全選與單選chekbox的自定義,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-07-07
Angularjs實現(xiàn)控制器之間通信方式實例總結
這篇文章主要介紹了Angularjs實現(xiàn)控制器之間通信方式,結合實例形式總結分析了AngularJS控制器常用通信方式及相關操作注意事項,需要的朋友可以參考下2018-03-03
簡介可以自動完成UI的AngularJS工具angular-smarty
這篇文章主要介紹了簡介可以自動完成UI的AngularJS工具angular-smarty,包括其中隔離作用域綁定指令符和promise的使用,需要的朋友可以參考下2015-06-06

