微信小程序圖片上傳功能的實現(xiàn)方法
前言
最近做了個小程序,涉及到了圖片上傳的功能,今天給大家詳細介紹下如何實現(xiàn)小程序圖片上傳,話不多說先上代碼
首先是靜態(tài)布局和樣式部分
.wxml代碼部分
<view class='load-img'>
<view class='load-box'>
<view class='img-item' wx:for="{{fileList}}" wx:key="index" >
<image src="{{item.path}}" data-src="{{item}}" mode="aspectFill" data-list="{{fileList}}" bindtap=""></image>
<icon class='icon' type="clear" size="20" color='#EF4444' catchtap='_onDelTab' data-idx="{{index}}" wx:if="{{!prevent}}"/>
</view>
<image class='img-add' bindtap='_addImg' wx:if="{{!prevent}}"></image>
</view>
</view>
.wxss代碼部分
/* 上傳圖片 */
.load-name {
height: 80rpx;
line-height: 80rpx;
font-size: 30rpx;
}
.load-box {
display: flex;
flex-direction: row;
flex-wrap: wrap;
}
.img-item, .img-add {
position: relative;
width: 140rpx;
height: 140rpx;
margin: 20rpx;
}
.img-add {
border: 1px solid #ccc;
}
.img-add:after{
width: 1rpx;
height: 50rpx;
content: " ";
position: absolute;
top: 50%;
left: 50%;
-webkit-transform: translate(-50%, -50%);
-ms-transform: translate(-50%, -50%);
transform: translate(-50%, -50%);
background-color: #ccc;
}
.img-add:before{
position: absolute;
top: 50%;
right: 31%;
width: 50rpx;
height: 1rpx;
content: " ";
display: inline-block;
background-color: #ccc;
}
.img-item {
margin-right: 20rpx;
}
.img-item image {
width: 100%;
height: 100%;
border-radius: 10rpx;
}
.icon {
position: absolute;
top: 0;
right: 0;
}
以上這些基本代碼就可以完成圖片上傳,顯示,刪除等樣式布局
下面是js的部分,我已詳細備注~~~
先來看下完整的代碼
/**
* 小程序圖片上傳
* 組件接受參數(shù)
* fileList 圖片數(shù)組
* prevent 控制是否可新增
* 方法
* bindimageChange 選擇圖片后觸發(fā)
* bindimageDel 刪除圖片后觸發(fā)
*
*/
const app = getApp();
Component({
properties: {
fileList: {
type: Array
},
prevent: {
type: Boolean,
value: false
}
},
data: {
fileList: []
},
ready() {},
methods: {
// 點擊加號進入手機相冊,并進行圖片選擇
_addImg() {
let _this = this;
// 此方法為微信小程序自帶api 詳情訪問https://developers.weixin.qq.com/miniprogram/dev/api/media/image/wx.chooseImage.html
wx.chooseImage({
count: 5,
success(res) {
//此處會返回圖片暫存路徑和文件大小
const data = res.tempFiles;
_this.setFile(data)
}
})
},
setFile (data) {
// 將wx.chooseImage返回的數(shù)據(jù)進行擴展
data.map((item, index) => {
// 通過路徑截取文件后綴名
const fileFormat = item.path.substring(item.path.lastIndexOf(".") + 1, item.path.length);
// wx.getFileSystemManager()小程序文件管理器api,可以將通過文件路徑將其轉(zhuǎn)換成64編碼
const fileManager = wx.getFileSystemManager();
const base64 = fileManager.readFileSync(item.path, 'base64');
item.fileContent = base64;
item.fileSize = item.size;
// 通過時間獲取隨機13位隨機數(shù)并且拼接文件后綴進行文件命名
item.fileName = this.getFileName(13) + '.' + fileFormat;
// 此處操作是用來進行選中圖片顯示的,只有這樣拼接才能顯示base64編碼的路徑
item.path = `data:image/${fileFormat};base64,${base64}`;;
})
this.setData({
fileList: this.data.fileList.concat(data)
});
// 此處操作是用來將獲取到的文件數(shù)據(jù)傳遞給父組件進行文件上傳
this.triggerEvent('imageChange', this.data.fileList)
},
// 隨機生成文件名
getFileName (m) {
m = m > 13 ? 13 : m;
var num = new Date().getTime();
return num.toString().substring(13 - m);
},
點擊進行圖片刪除
_onDelTab(e) {
// 獲取圖片索引
let idx = e.currentTarget.dataset.idx;
let delFile = this.data.fileList[idx];
console.log(delFile);
this.data.fileList.splice(idx, 1);
this.setData({
fileList: this.data.fileList
})
this.triggerEvent('imageDel', delFile);
}
})
代碼里對代碼的備注已經(jīng)很明確了,大家仔細扒一下,根據(jù)的自己的項目進行相應(yīng)的調(diào)整,基本上都是沒問題的,~~不要直接直接粘貼不復(fù)置,我是直接在我的項目中直接拿過來的代碼,直接粘貼復(fù)制肯定是不行的?。。?/strong>~~
大家需要注意的是這里

通常在真機上點擊選中圖片后wx.chooseImage方法中返回的文件路徑是wxfile:開頭的路徑,這樣的路徑想直接轉(zhuǎn)成base64,上面的方式是可以實現(xiàn)的,我也是查了很多資料才找到的解決辦法。
再一個需要注意的是image src屬性想顯示base64格式的圖片要進行字符串拼接才可以正常顯示如下圖

好啦這些就是我小程序上傳圖片的操作,這些只是我對日常工作的積累,不喜勿噴 不喜勿噴 不喜勿噴 重要的事情說三遍,大家仔細看下代碼理解用法,還是很簡單的,看都不看想白漂肯定是不行的呦~~~~~~~~~
總結(jié)
到此這篇關(guān)于微信小程序圖片上傳功能的文章就介紹到這了,更多相關(guān)微信小程序圖片上傳功能內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在網(wǎng)頁里看flash的trace數(shù)據(jù)的js類
我的js類jdhcn.js中的一個flashDebug方法2009-01-01
使用json對象轉(zhuǎn)化為key,value的對象數(shù)組
這篇文章主要介紹了使用json對象轉(zhuǎn)化為key,value的對象數(shù)組方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-06-06
JS如何遍歷帶有子集的數(shù)組集合(嵌套數(shù)組)
這篇文章主要介紹了JS如何遍歷帶有子集的數(shù)組集合(嵌套數(shù)組)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-06-06

