欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue?vant-ui使用van-uploader實(shí)現(xiàn)頭像上傳功能

 更新時間:2022年05月21日 10:15:57   作者:船長在船上  
這篇文章主要介紹了Vue?vant-ui使用van-uploader實(shí)現(xiàn)頭像圖片上傳,項(xiàng)目中是使用有贊vant-ui框架實(shí)現(xiàn)的頭像上傳替換功能,用到了封裝的圖片壓縮封裝之后再去上傳圖片this.$imgUpload.imgZip(),本文通過實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友參考下吧

效果圖:

項(xiàng)目中是使用有贊vant-ui框架實(shí)現(xiàn)的頭像上傳替換功能

代碼布局結(jié)構(gòu): 

<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)質(zhì)船主
              </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");
    },
    // 上傳之前的圖片驗(yàn)證
    beforeRead(file) {
      if (this.$utils.isImage(file.name)) {
        return true;
      } else {
        this.$toast.fail("請上傳圖片格式");
      }
    },
    // 頭像上傳  文件上傳完畢后會觸發(fā) after-read 回調(diào)函數(shù),獲取到對應(yīng)的 file 對象。
    afterCard(file) {
 
      this.$imgUpload.imgZip(file).then(resData => {
        const formData = new FormData();
        formData.append("file", resData);
 
        // 請求接口上傳圖片到服務(wù)器
        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);
          }
        });
      });
    },

關(guān)于圖片壓縮方法、拍照上傳的圖片被旋轉(zhuǎn) 90 度問題解決方法 后期會更新上去

Uploader 在部分安卓機(jī)型上無法上傳圖片?

Uploader 采用了 HTML 原生的 <input type="file /> 標(biāo)簽進(jìn)行上傳,能否上傳取決于當(dāng)前系統(tǒng)和瀏覽器的兼容性。當(dāng)遇到無法上傳的問題時,一般有以下幾種情況:

  • 遇到了安卓 App WebView 的兼容性問題,需要在安卓原生代碼中進(jìn)行兼容,可以參考文末擴(kuò)展知識點(diǎn)
  • 圖片格式不正確,在當(dāng)前系統(tǒng)/瀏覽器中無法識別,比如 webp 或 heic 格式。
  • 其他瀏覽器兼容性問題。

擴(kuò)展知識點(diǎn):安卓10訪問手機(jī)相冊 有讀寫權(quán)限但是還是訪問不到問題解決方案

安卓10訪問手機(jī)相冊 有讀寫權(quán)限但是還是訪問不到問題解決方案

原因 安卓10 或者是打包target版本大于等于29的時候。就算有讀寫sd卡權(quán)限,谷歌依舊有限制。

解決方案1:

把target版本調(diào)整到 29以下

解決方案2:

修改androidmanifest.xml文件 在 <application 標(biāo)簽里再添加一個屬性
android:requestLegacyExternalStorage=“true”

至于為什么target : 29以下可以呢 是因?yàn)楣雀枘J(rèn)29以下的 這個屬性自動為true
到29開始就要手動填。 坑爹的谷歌!?。?/p>

到此這篇關(guān)于Vue vant-ui使用van-uploader實(shí)現(xiàn)頭像圖片上傳的文章就介紹到這了,更多相關(guān)Vue 圖片上傳內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue簡單實(shí)現(xiàn)原理詳解

    Vue簡單實(shí)現(xiàn)原理詳解

    這篇文章主要介紹了Vue簡單實(shí)現(xiàn)原理,結(jié)合實(shí)例形式詳細(xì)分析了Vue實(shí)現(xiàn)原理與操作注意事項(xiàng),需要的朋友可以參考下
    2020-05-05
  • Vue指令工作原理實(shí)現(xiàn)方法

    Vue指令工作原理實(shí)現(xiàn)方法

    自定義指令是 vue 中使用頻率僅次于組件,其包含 bind 、 inserted 、 update 、 componentUpdated 、 unbind 五個生命周期鉤子,接下來通過本文給大家詳細(xì)介紹Vue指令工作原理實(shí)現(xiàn)方法,需要的朋友參考下吧
    2021-06-06
  • vue+element創(chuàng)建動態(tài)的form表單及動態(tài)生成表格的行和列

    vue+element創(chuàng)建動態(tài)的form表單及動態(tài)生成表格的行和列

    這篇文章主要介紹了vue+element創(chuàng)建動態(tài)的form表單及動態(tài)生成表格的行和列 ,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-05-05
  • Vue路由的模塊自動化與統(tǒng)一加載實(shí)現(xiàn)

    Vue路由的模塊自動化與統(tǒng)一加載實(shí)現(xiàn)

    這篇文章主要介紹了Vue路由的模塊自動化與統(tǒng)一加載實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • VSCode搭建Vue項(xiàng)目的方法

    VSCode搭建Vue項(xiàng)目的方法

    這篇文章主要介紹了VSCode搭建Vue項(xiàng)目的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Vue組件層級關(guān)系詳細(xì)分析

    Vue組件層級關(guān)系詳細(xì)分析

    這篇文章主要介紹了Vue組件的層級關(guān)系,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • vue設(shè)置頁面超時15分鐘自動退出登錄的方法詳解

    vue設(shè)置頁面超時15分鐘自動退出登錄的方法詳解

    當(dāng)用戶登錄后,如果長時間未操作頁面這個時候需要自動退出登錄回到登錄頁面,本文將給大家介紹一下vue設(shè)置頁面超時15分鐘自動退出登錄的方法,感興趣的同學(xué)可以自己動手試一下
    2023-10-10
  • Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用

    Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用

    這篇文章主要介紹了Vue全局共享數(shù)據(jù)之globalData,vuex,本地存儲的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 在vue中實(shí)現(xiàn)禁止屏幕滾動,禁止屏幕滑動

    在vue中實(shí)現(xiàn)禁止屏幕滾動,禁止屏幕滑動

    這篇文章主要介紹了在vue中實(shí)現(xiàn)禁止屏幕滾動,禁止屏幕滑動,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • vue中的echarts實(shí)現(xiàn)寬度自適應(yīng)的解決方案

    vue中的echarts實(shí)現(xiàn)寬度自適應(yīng)的解決方案

    這篇文章主要介紹了vue中的echarts實(shí)現(xiàn)寬度自適應(yīng),本文給大家分享實(shí)現(xiàn)方案,代碼簡單易懂,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-09-09

最新評論