詳解angularJS+Ionic移動端圖片上傳的解決辦法
前端開發(fā)中經(jīng)常會碰到圖片上傳的問題,網(wǎng)上的解決辦法很多,可是有些圖片上傳的插件會有一些附屬的插件,因此因為一個圖片上傳的問題可能額需要引入其他插件到項目中,久而久之項目會不倫不類,有時候插件之間也會有一些沖突,所以我們可以自己寫一個圖片上傳的方法。
今天的demo是幫朋友做的一個移動端微信公眾號項目,項目架構(gòu)采用angular+ionic,因為對dom的操作jQuery會方便很多,但是jQuery比較厚重,所以最后選擇用輕量級的zepto來對項目dom進行操作。
項目中有一個需求是上傳個人作品,實現(xiàn)功能需要H5新對象 FormData對象、XMLHttpRequest對象、FileReader對象。只需要這三個對象即可,話不多說上代碼。
dom結(jié)構(gòu):

js結(jié)構(gòu):
function1:
$scope.imgList = [];
$scope.setUploader = function () {
var files = document.getElementById('photo');
files.click();
$(files).unbind().on('change',function (e) {
var file = e.target.value;
if (!/.(jpg|jpeg|png|GIF|JPG|png)$/.test(file)) {
common.toast('圖片類型必須是jpeg,jpg,png中的一種');
return false;
};
fsubmit();
readAsBinaryString();
});
};
function2:
function fsubmit() {
var itemImg = {};
var form=document.getElementById("form1");
console.log('form',form)
var formData=new FormData(form);
formData.append('wxdesigner_sid',$.fn.cookie('wxdesigner_sid'));
formData.append('id',$scope.masterInfo.id);
formData.append('pc','1');
var oReq = new XMLHttpRequest();
oReq.onreadystatechange=function(){
if(oReq.readyState==4){
if(oReq.status==200){
var json=JSON.parse(oReq.responseText);
console.log(json)
if(json.Success) {
itemImg = json.Data;
$scope.imgList=itemImg;
console.log($scope.imgList)
$scope.$apply();
itemImg = {};
}
}
}
};
console.log(oReq)
console.log(formData)
oReq.open("POST", common.api+"Wxdesigner/Designer/uploadworks");
oReq.send(formData);
return false;
};
//判斷瀏覽器是否支持FileReader接口
if(typeof FileReader == 'undefined'){
//使選擇控件不可操作
file.setAttribute("disabled","disabled");
}
function3:
function readAsBinaryString(){
var file = document.getElementById('photo').files[0];
console.log(file)
var reader = new FileReader();
//將文件以二進制形式讀入頁面
reader.readAsDataURL(file);
reader.onload=function(f){
$scope.masterInfo.thumblist.push(f.currentTarget.result)
console.log($scope.masterInfo)
$scope.$apply()
}
}
整個圖片上傳的dom層很簡單,一個form表單加上一個觸發(fā)表單的函數(shù)(function1)。在function1中獲取到<input type="file">的點擊事件,在選擇圖片的時候會做個判斷,如果超出支持的圖片類型圍的時候做個提醒。
然后在后面調(diào)用function2和function3。
在function2中獲取form表單對象,然后創(chuàng)建一個FormData對象,將獲取到的form表單傳入FormData,然后append一些上傳圖片的參數(shù)。再創(chuàng)建一個new XMLHttpRequest對象,然后open發(fā)送XHR請求接口,send(formData)傳遞參數(shù)給接口。
到這個時候接口發(fā)送成功。

這里的四個參數(shù)是formData中的四個參數(shù)

接口相應(yīng)成功。
到這里有問題,圖片上傳成功寫入數(shù)據(jù)庫了,可是這時候需要在本地展示給用戶看但是網(wǎng)頁又不能直接訪問設(shè)備本地的圖片,因此我們需要FIleReader對象來對上傳的圖片文件讀取為DataURL來展示在本地。
首先New 一個FileReader對象,然后將獲取到的input file對象傳入FileReader的 readAsDataURL()方法,此方法是將文件讀取為DataURL的。
然后調(diào)用FileReader的onload方法,此方法的result會有轉(zhuǎn)換之后的url,因此我們可以獲取到此url,實際上是經(jīng)過base64編碼的。然后push到圖片列表的最后

到此解決了問題,前端展示了本地的圖片并且圖片也寫入了數(shù)據(jù)庫,當頁面再次刷新的時候拿到的是數(shù)據(jù)庫中的數(shù)據(jù)

當然這里只是一個方法,移動端圖片上傳的插件比比皆是,甚至各種拖拽上傳的圖片上傳插件也很多,此處適合項目中不用引入插件的圖片上傳的簡單功能。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
深入淺析angular和vue還有jquery的區(qū)別
vue是一個漸進式的框架, 是一個輕量級的框架而angular是一個mvc框架, 各有千秋,下面小編通過本文給大家介紹angular和vue還有jquery的區(qū)別,感興趣的朋友一起看看吧2018-08-08
關(guān)于AngularJS中幾種Providers的區(qū)別總結(jié)
這篇文章主要給大家介紹了關(guān)于AngularJS中幾種Providers的區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學(xué)習(xí)或者使用AngularJS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2020-05-05
ng2學(xué)習(xí)筆記之bootstrap中的component使用教程
現(xiàn)在angular2已經(jīng)除了集成的angular-cli,建議大家可以基于這個來快速開發(fā)ng2的項目,不用自己再搭建環(huán)境。接下來通過本文給大家介紹 bootstrap中的component使用教程,需要的朋友可以參考下2017-03-03
BootStrap+Angularjs+NgDialog實現(xiàn)模式對話框
在完成一個后臺管理系統(tǒng)時,需要用表格顯示注冊用戶的信息。但是用戶地址太長了,不好顯示。所以想做一個模式對話框,點擊詳細地址按鈕時,彈出對話框,顯示地址。下面小編給大家分享下實現(xiàn)方法,一起看下吧2016-08-08
利用require.js與angular搭建spa應(yīng)用的方法實例
這篇文章主要給大家介紹了關(guān)于利用require.js與angular搭建spa應(yīng)用的方法實例,文中通過示例代碼給大家介紹的非常詳細,對大家的理解和學(xué)習(xí)具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編來一起看看吧。2017-07-07
AngularJS實現(xiàn)的根據(jù)數(shù)量與單價計算總價功能示例
這篇文章主要介紹了AngularJS實現(xiàn)的根據(jù)數(shù)量與單價計算總價功能,涉及AngularJS事件響應(yīng)與數(shù)值運算相關(guān)操作技巧,需要的朋友可以參考下2017-12-12

