微信小程序 拍照或從相冊選取圖片上傳代碼實(shí)例
這篇文章主要介紹了微信小程序 拍照或從相冊選取圖片上傳代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
upload.wxml
<!--pages/upload/upload.wxml--> <button bindtap='uploadPhoto'>拍照選取照片上傳</button>
upload.js
// pages/upload/upload.js
Page({
data: {
imgData: []
},
uploadPhoto(e) { // 拍攝或從相冊選取上傳
let that = this;
wx.chooseImage({
count: 1, // 默認(rèn)9
sizeType: ['compressed'], // 可以指定是原圖還是壓縮圖,默認(rèn)二者都有
sourceType: ['album', 'camera'], // 可以指定來源是相冊還是相機(jī),默認(rèn)二者都有
success(res) {
let tempFilePaths = res.tempFilePaths; // 返回選定照片的本地路徑列表
that.upload(that, tempFilePaths);
}
})
},
upload(page, path) { // 上傳圖片
wx.showToast({ icon: "loading", title: "正在上傳……" });
wx.uploadFile({
url: '上傳圖片接口url', //后端接口
filePath: path[0],
name: 'file',
header: {
"Content-Type": "multipart/form-data"
},
success(res) {
if (res.statusCode != 200) {
wx.showModal({ title: '提示', content: '上傳失敗', showCancel: false });
return;
} else{
console.log("上傳成功! 可對返回的值進(jìn)行操作,比如:存入imgData;");
}
},
fail(e) {
wx.showModal({ title: '提示', content: '上傳失敗', showCancel: false });
},
complete() {
wx.hideToast(); //隱藏Toast
}
})
}
})
ps:以上是單圖上傳,如果需要多圖上傳,請看下方:
// pages/publish/publish.js
Page({
data: {
imgData: []
},
uploadPhoto(e) { // 拍攝或從相冊選取上傳
let that = this;
wx.chooseImage({
count: 9 - that.data.imgData.length, // 默認(rèn)最多上傳9張
sizeType: ['compressed'], // 可以指定是原圖還是壓縮圖,默認(rèn)二者都有
sourceType: ['album', 'camera'], // 可以指定來源是相冊還是相機(jī),默認(rèn)二者都有
success(res) {
let tempFilePaths = res.tempFilePaths; // 返回選定照片的本地路徑列表
that.upload(that, tempFilePaths);
}
})
},
upload(page, path) { // 上傳圖片
let that = this;
wx.showToast({ icon: "loading", title: "正在上傳……" });
for (var i=0; i<path.length; i++) {
wx.uploadFile({
url: '上傳圖片接口url', //后端接口
filePath: path[i],
name: 'file',
header: app.globalData.header,
success(res) {
if (res.statusCode != 200) {
wx.showModal({
title: '提示',
content: '第' + i +'張圖片上傳失敗',
showCancel: false
});
return;
} else {
console.log('第' + i +'張圖片上傳成功!可在此操作,比如:存入imgData;');
}
},
fail(e) {
wx.showModal({
title: '提示',
content: '第' + i +'張圖片上傳失敗',
showCancel: false
});
},
complete() {
wx.hideToast(); //隱藏Toast
}
})
}
}
})
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript實(shí)現(xiàn)省市區(qū)三級聯(lián)動(dòng)下拉框菜單
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)省市區(qū)三級聯(lián)動(dòng)下拉框菜單很詳細(xì)的代碼,解決了大家實(shí)現(xiàn)javascript省市區(qū)三級聯(lián)動(dòng)下拉框菜單的問題,感興趣的小伙伴們可以參考一下2015-11-11
javascript相等運(yùn)算符與等同運(yùn)算符詳細(xì)介紹
不管是java、c++、php都有相等運(yùn)算符與等同運(yùn)算符,當(dāng)然javasript也不例外,下面介紹一下2013-11-11
使用JavaScrip實(shí)現(xiàn)一個(gè)記憶函數(shù)
在編程的世界里,性能優(yōu)化始終是一個(gè)重要的話題,今天,我們將一起來實(shí)現(xiàn)一個(gè)實(shí)用的記憶函數(shù),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一2024-11-11
Echarts中常用的參數(shù)總結(jié)及參數(shù)自定義示例代碼
Echarts中參數(shù)的配置功能很強(qiáng)大,對任何一項(xiàng)的配置都很細(xì)致,下面這篇文章主要給大家介紹了關(guān)于Echarts中常用的參數(shù)總結(jié)及參數(shù)自定義的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-02-02
BOM系列第一篇之定時(shí)器setTimeout和setInterval
這篇文章主要介紹了BOM系列第一篇之定時(shí)器setTimeout和setInterval 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-08-08
基于JS實(shí)現(xiàn)任務(wù)隊(duì)列的示例代碼
顧名思義,任務(wù)隊(duì)列就是存放任務(wù)的隊(duì)列,隊(duì)列中的任務(wù)都嚴(yán)格按照進(jìn)入隊(duì)列的先后順序執(zhí)行,所以下面我們就來看看如何基于JS實(shí)現(xiàn)任務(wù)隊(duì)列吧2023-08-08
JavaScript實(shí)現(xiàn)移動(dòng)端短信驗(yàn)證碼流程介紹
這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)移動(dòng)端發(fā)送短信驗(yàn)證碼案例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-10-10

