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

vant中如何修改用戶的頭像

 更新時間:2022年08月11日 09:42:01   作者:A黃俊輝A  
這篇文章主要介紹了vant中如何修改用戶的頭像,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vant修改用戶的頭像

我們的項目中經常會遇到用戶個人信息的修改,當然用的組件就是 vant 中的 van-uploader 組件, 但是這個組的是有一個回顯功能的, 它的樣式不太符合我們, 更改用戶頭像的場景

對比一下

van-uploader 的本來的樣式是這樣的

而我們需要修改用戶頭像的樣式是這樣的

我們的需求就是 上傳完圖像之后, 再次點擊頭像, 還可以再次上傳一個新的頭像, 這樣的需求, van-uploader 中的 fileList是實現(xiàn)不了的

那么我是怎么實現(xiàn)這個功能的呢?

我沒有使用 van-uploader 的 fileList 屬性, 我使用的它的一個 slot 的插槽功能

圖中的 van-image 的src 是寫死了的, 它可以通過 接口請求返回的數(shù)據(jù)來改變。會的都會,不用多說

這樣就實現(xiàn)我們的想要的功能

vant實現(xiàn)純客戶端用戶頭像上傳預覽

<style lang="less" scoped>
.EditUserINfo {
  .avatar {
    width: 30px;
    height: 30px;
  }
  /* 樣式穿透 */ 
  /deep/ .van-image-preview__cover{
    /* 取消樣式設置 */
    top: unset;
    left: 0;
    right: 0;
    bottom: 0;
    .van-nav-bar{
      background: #000;
    }
  }
}
</style>
<template>
  <div class="EditUserINfo">
    <van-nav-bar title="編輯資料" left-arrow @click-left="$router.back()"></van-nav-bar>
    <van-cell-group>
      <van-cell title="頭像" is-link @click="onAvatarClick">
        <van-image class="avatar" round :src="user.photo" />
      </van-cell>
      <!-- 表單元素的hidden屬性:隱藏表單元素 -->
      <input type="file" hidden ref="file" @change="onFileChange" />
      <van-cell title="昵稱" is-link :value="user.name"></van-cell>
      <van-cell title="介紹" is-link value="內容"></van-cell>
      <van-cell title="性別" is-link :value="user.gender===0?'男':'女'"></van-cell>
      <van-cell title="生日" is-link :value="user.birthday"></van-cell>
    </van-cell-group>
    <!-- 頭像預覽,預覽關閉文件重置 -->
    <van-image-preview v-model="isPreviewShow" :images="images" @close="$refs.file.value=''">
      <!-- 插入插槽cover -->
      <van-nav-bar
        slot="cover"
        left-text="取消"
        right-text="確定"
        @click-left="isPreviewShow=false"
        @click-right="onUpdateAvatar"
      />
    </van-image-preview>
  </div>
</template>
 
<script>
export default {
  name: "EditUserINfo",
  components: {},
  props: {},
  data() {
    return {
      user: {
        photo: "https://img.yzcdn.cn/vant/cat.jpeg",
        name: "凱文",
        gender: "男",
        birthday: "1996-12-18"
      }, //用戶信息
      isPreviewShow: false,
      images: [] //預覽圖片列表
    };
  },
  watch: {},
  computed: {
    file() {
      return this.$refs["file"];
    }
  },
  methods: {
    onAvatarClick() {
      this.file.click();
    },
    onFileChange() {
      // 1.拿到file類型input選擇的文件對象
      const fileObj = this.file.files[0];
      // 2.使用window.URL.createObjectURL(file)得到文件數(shù)據(jù)
      const fileData = window.URL.createObjectURL(fileObj);
      // 3.將img.src = 第2步的結果
      this.images = [fileData];
      this.isPreviewShow = true;
    },
    onUpdateAvatar() {
      // 1.構造包含文件數(shù)據(jù)的表單對象
      // 注意:含有文件的服務務必要放到FormData中
      // 用代碼來構造一個表單對象,主要目的是用來異步發(fā)送文件上傳
      // 參數(shù)一:鍵
      // 參數(shù)二:值
      const fd = new FormData()
      fd.append('photo',this.file.files[0])
      this.$toast.loading({
        duration: 1000,
        message:'保存中',
        forbidClick:true
      })
      this.isPreviewShow =false
      //this.$toast.success('保存成功')
    }
  },
  created() {},
  mounted() {}
};
</script>

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • el-table實現(xiàn)轉置表格的示例代碼(行列互換)

    el-table實現(xiàn)轉置表格的示例代碼(行列互換)

    這篇文章主要介紹了el-table實現(xiàn)轉置表格的示例代碼(行列互換),本文結合示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2024-02-02
  • vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)

    vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)

    最近工作中實現(xiàn)的一個效果不錯,分享給大家,下面這篇文章主要給大家介紹了關于vue項目實戰(zhàn)之圓柱狀水波效果實現(xiàn)的相關資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-12-12
  • vue input實現(xiàn)點擊按鈕文字增刪功能示例

    vue input實現(xiàn)點擊按鈕文字增刪功能示例

    這篇文章主要介紹了vue input實現(xiàn)點擊按鈕文字增刪功能,涉及基于vue.js的事件響應及頁面元素屬性動態(tài)操作相關實現(xiàn)技巧,需要的朋友可以參考下
    2019-01-01
  • 詳解vue父子組件狀態(tài)同步的最佳方式

    詳解vue父子組件狀態(tài)同步的最佳方式

    這篇文章主要介紹了vue父子組件狀態(tài)同步的最佳方式,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • vue+element實現(xiàn)動態(tài)加載表單

    vue+element實現(xiàn)動態(tài)加載表單

    這篇文章主要為大家詳細介紹了vue+element實現(xiàn)動態(tài)加載表單,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-12-12
  • Vue中Router路由兩種模式hash與history詳解

    Vue中Router路由兩種模式hash與history詳解

    這篇文章主要介紹了Vue中Router路由的兩種模式,分別對hash模式與history模式作了簡要分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • 自定義Vue中的v-module雙向綁定的實現(xiàn)

    自定義Vue中的v-module雙向綁定的實現(xiàn)

    這篇文章主要介紹了自定義Vue中的v-module雙向綁定的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • Vite多環(huán)境配置項目高定制化能力詳解

    Vite多環(huán)境配置項目高定制化能力詳解

    這篇文章主要為大家介紹了Vite多環(huán)境配置項目高定制化能力詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 仿照Element-ui實現(xiàn)一個簡易的$message方法

    仿照Element-ui實現(xiàn)一個簡易的$message方法

    這篇文章主要介紹了仿照Element-ui實現(xiàn)一個簡易的$message方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-09-09
  • 從vue源碼看props的用法

    從vue源碼看props的用法

    平時寫vue的時候知道 props 有很多種用法,今天我們來看看vue內部是怎么處理 props 中那么多的用法的。非常具有實用價值,需要的朋友可以參考下
    2019-01-01

最新評論