小編給大家分享一下AngularJS怎么實現(xiàn)圖片上傳和預(yù)覽功能的方法分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)建站專注為客戶提供全方位的互聯(lián)網(wǎng)綜合服務(wù),包含不限于成都網(wǎng)站設(shè)計、做網(wǎng)站、伍家崗網(wǎng)絡(luò)推廣、重慶小程序開發(fā)公司、伍家崗網(wǎng)絡(luò)營銷、伍家崗企業(yè)策劃、伍家崗品牌公關(guān)、搜索引擎seo、人物專訪、企業(yè)宣傳片、企業(yè)代運營等,從售前售中售后,我們都將竭誠為您服務(wù),您的肯定,是我們大的嘉獎;創(chuàng)新互聯(lián)建站為所有大學(xué)生創(chuàng)業(yè)者提供伍家崗建站搭建服務(wù),24小時服務(wù)熱線:028-86922220,官方網(wǎng)址:www.cdcxhl.com1、能夠嵌入動態(tài)文本于HTML頁面。2、對瀏覽器事件做出響應(yīng)。3、讀寫HTML元素。4、在數(shù)據(jù)被提交到服務(wù)器之前驗證數(shù)據(jù)。5、檢測訪客的瀏覽器信息。6、控制cookies,包括創(chuàng)建和修改等。7、基于Node.js技術(shù)進(jìn)行服務(wù)器端編程。
html5原生方法
先看一下html5原生方法上傳和預(yù)覽圖片的實現(xiàn):
// var imgPreview = document.getElementById("img-preview"); // 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中,不支持ng-model和ng-change指令(附錄1),這就使得文件上傳變得有些復(fù)雜了。
angularjs方法
這里使用開源的 angular-file-upload 模塊來實現(xiàn),步驟如下:
1、安裝 angular-file-upload 模塊
bower install angular-file-upload --save
2、添加到應(yīng)用依賴
var app = angular.module('my-app', [ 'angularFileUpload' ]);
3、HTML代碼
這里,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,再更新標(biāo)簽的src屬性即可。
值得注意的是,我們把“更新標(biāo)簽的src屬性”這個任務(wù)放到了$scope.$apply方法中執(zhí)行,這是因為在angular框架外部(如在瀏覽器DOM事件中, setTimeout, XHR 或者 第三方框架中)更新數(shù)據(jù),angular是不會同步更新綁定的。這點可以參考angular $apply reference
以上是“AngularJS怎么實現(xiàn)圖片上傳和預(yù)覽功能的方法分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。