Vue?vant-ui使用van-uploader實現(xiàn)頭像上傳功能
效果圖:


項目中是使用有贊vant-ui框架實現(xiàn)的頭像上傳替換功能
代碼布局結構:
<van-row class="sendInfo">
<van-col span="24" class="flex colorf topInfo p20">
<!--左邊頭像部分-->
<van-uploader :after-read="afterCard" :before-read="beforeRead" accept="image/*" class="arrart"
:max-size="10240 * 1024" @oversize="onOversize">
<img class="arrart"
:src=" centerInfo.iconUrl ? $baseImgUrl + centerInfo.iconUrl : require('../../assets/img/touciang.png')" />
<!-- <van-tag type="danger" class="vip" size="medium">VIP</van-tag> -->
<div class="personCompany">{{loginType==0?"個人用戶":"企業(yè)用戶"}}</div>
</van-uploader>
<!--右邊部分-->
<div class="ml30">
<div class="flex rightVip">
<span class="fontSize36 color0 mt20 van-ellipsis">郝先生</span>
<img :src="vipImg" width="46" height="20" class="mt20" style="padding-left:12px;" v-show="centerInfo.memberLevel==1" />
</div>
<div class="flex mt30">
<van-icon class="editIcon vmd mr10" color="#999" name="edit" />
<div class="fontSize30 color9 personInfo van-multi-ellipsis--l2">
優(yōu)質船主
</div>
</div>
</div>
</van-col>
</van-row>樣式:
.flex {
display: flex;
width: 100%;
}
.topInfo {
align-items: center;
background-color: #fff;
// border-radius: 24px;
}
.arrart {
width: 128px;
height: 128px;
border-radius: 50%;
}
.personCompany {
position: absolute;
top: 100px;
left: 0px;
font-size: 0.4rem;
width: 128px;
height: 40px;
text-align: center;
background: #333440;
border-radius: 50px;
color: #ffdd99;
// padding:0px 6px;
line-height: 40px;
}
.rightVip {
width: 552px;
align-items: center;
}主要方法:這里用到了封裝的圖片壓縮封裝之后再去上傳圖片this.$imgUpload.imgZip()
//定義存儲對象
centerInfo: {},// 限制上傳大小圖片
onOversize(file) {
this.$toast("文件大小不能超過 10M");
},
// 上傳之前的圖片驗證
beforeRead(file) {
if (this.$utils.isImage(file.name)) {
return true;
} else {
this.$toast.fail("請上傳圖片格式");
}
},
// 頭像上傳 文件上傳完畢后會觸發(fā) after-read 回調函數(shù),獲取到對應的 file 對象。
afterCard(file) {
this.$imgUpload.imgZip(file).then(resData => {
const formData = new FormData();
formData.append("file", resData);
// 請求接口上傳圖片到服務器
uploadImg(formData).then(res => {
if (res.code == 200) {
this.centerInfo.iconUrl = res.data;
let params = {
iconUrl: res.data,
id: this.id,
loginType: this.loginType
};
updateMineIconUrl(params)
.then(resImg => {
if (resImg.code == 200) {
this.$toast("頭像修改成功");
} else {
this.$toast(res.msg);
}
})
.catch(error => {});
} else {
this.$toast(res.msg);
}
});
});
},關于圖片壓縮方法、拍照上傳的圖片被旋轉 90 度問題解決方法 后期會更新上去
Uploader 在部分安卓機型上無法上傳圖片?
Uploader 采用了 HTML 原生的 <input type="file /> 標簽進行上傳,能否上傳取決于當前系統(tǒng)和瀏覽器的兼容性。當遇到無法上傳的問題時,一般有以下幾種情況:
- 遇到了安卓 App WebView 的兼容性問題,需要在安卓原生代碼中進行兼容,可以參考文末擴展知識點。
- 圖片格式不正確,在當前系統(tǒng)/瀏覽器中無法識別,比如
webp或heic格式。 - 其他瀏覽器兼容性問題。
擴展知識點:安卓10訪問手機相冊 有讀寫權限但是還是訪問不到問題解決方案
安卓10訪問手機相冊 有讀寫權限但是還是訪問不到問題解決方案
原因 安卓10 或者是打包target版本大于等于29的時候。就算有讀寫sd卡權限,谷歌依舊有限制。
解決方案1:
把target版本調整到 29以下
解決方案2:
修改androidmanifest.xml文件 在 <application 標簽里再添加一個屬性
android:requestLegacyExternalStorage=“true”至于為什么target : 29以下可以呢 是因為谷歌默認29以下的 這個屬性自動為true
到29開始就要手動填。 坑爹的谷歌?。?!
到此這篇關于Vue vant-ui使用van-uploader實現(xiàn)頭像圖片上傳的文章就介紹到這了,更多相關Vue 圖片上傳內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue element-ui實現(xiàn)el-table表格多選以及回顯方式
這篇文章主要介紹了vue element-ui實現(xiàn)el-table表格多選以及回顯方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-07-07
vue-cli是什么及創(chuàng)建vue-cli項目的方法
vue-cli是 vue 官方提供的、快速生成 vue 工程化項目的工具,支持創(chuàng)建vue2和vue3的項目,本文給大家詳細講解vue-cli是什么及創(chuàng)建vue-cli項目的方法,感興趣的朋友跟隨小編一起看看吧2023-04-04
Vue百度地圖實現(xiàn)定位和marker拖拽監(jiān)聽功能
這篇文章主要介紹了Vue百度地圖實現(xiàn)定位和marker拖拽監(jiān)聽功能,實現(xiàn)思路非常簡單,本文結合實例代碼效果圖給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-11-11
vue?select組件綁定的值為數(shù)字類型遇到的問題
這篇文章主要介紹了vue?select組件綁定的值為數(shù)字類型遇到的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-09-09
解決vue報錯:Do?not?mutate?vuex?store?state?outside?mutati
這篇文章主要介紹了解決vue報錯:Do?not?mutate?vuex?store?state?outside?mutation?handlers問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-05-05
使用yarn?build?打包vue項目時靜態(tài)文件或圖片未打包成功的問題及解決方法
這篇文章主要介紹了使用yarn?build?打包vue項目時靜態(tài)文件或圖片未打包成功的問題及解決方法,解決方法不復雜通過實例代碼給大家介紹的非常詳細,需要的朋友可以參考下2023-08-08

