AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法分析
本文實(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)項目使用上angularjs時,很自然的,我們想到了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屬性”這個任務(wù)放到了$scope.$apply方法中執(zhí)行,這是因?yàn)樵赼ngular框架外部(如在瀏覽器DOM事件中, setTimeout, XHR 或者 第三方框架中)更新數(shù)據(jù),angular是不會同步更新綁定的。這點(diǎn)可以參考angular $apply reference
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進(jìn)階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對大家AngularJS程序設(shè)計有所幫助。
- js實(shí)現(xiàn)圖片上傳并預(yù)覽功能
- Javascript圖片上傳前的本地預(yù)覽實(shí)例
- js圖片上傳前預(yù)覽功能(兼容所有瀏覽器)
- js實(shí)現(xiàn)圖片上傳預(yù)覽原理分析
- 圖片上傳之前檢查大小、尺寸、格式并預(yù)覽的js代碼
- Vue.js 2.0 移動端拍照壓縮圖片上傳預(yù)覽功能
- js前端實(shí)現(xiàn)多圖圖片上傳預(yù)覽的兩個方法(推薦)
- vue.js 圖片上傳并預(yù)覽及圖片更換功能的實(shí)現(xiàn)代碼
- 兼容IE和FF的圖片上傳前預(yù)覽js代碼
- JavaScript實(shí)現(xiàn)圖片上傳并預(yù)覽并提交ajax
相關(guān)文章
AngularJS ng-bind 指令簡單實(shí)現(xiàn)
本文主要介紹AngularJS ng-bind 指令,在這里對ng-bind 指令做了詳細(xì)資料整理并講解,提供了實(shí)例代碼以便大家參考,有需要的小伙伴可以參考下2016-07-07
angular使用bootstrap方法手動啟動的實(shí)例代碼
本篇文章主要介紹了angular使用bootstrap方法手動啟動的實(shí)例代碼,具有一定的參考價值,有興趣的可以了解一下2017-07-07
Bootstrap和Angularjs配合自制彈框的實(shí)例代碼
今天小編通過本文給大家分享Bootstrap和Angularjs配合自制彈框的實(shí)例代碼,代碼簡單易懂,有需要的朋友跟著小編一起學(xué)習(xí)2016-08-08
angular實(shí)現(xiàn)導(dǎo)航菜單切換
這篇文章主要為大家詳細(xì)介紹了angular實(shí)現(xiàn)導(dǎo)航菜單切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
Angular2從搭建環(huán)境到開發(fā)步驟詳解
本文的內(nèi)容主要是想幫助那些想學(xué)習(xí)Angular2的朋友們,因?yàn)槲易约涸谕鍭ngular2時碰到了不少坑,而且Angular2語法一直處于變化中,讓人很頭疼。不過也怪不了Anguar2,因?yàn)樗F(xiàn)在是處于并長期處于alpha階段,下面就通過本文來學(xué)習(xí)Angular2的搭建環(huán)境和開發(fā)吧。2016-10-10
淺談關(guān)于angularJs中使用$.ajax的注意點(diǎn)
本篇文章主要介紹了關(guān)于angularJs中使用$.ajax的注意點(diǎn),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-08-08

