亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue封裝組件之上傳圖片組件

 更新時(shí)間:2021年10月28日 17:14:27   作者:程程0221  
這篇文章主要為大家詳細(xì)介紹了vue封裝組件之上傳圖片組件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了vue上傳圖片組件的封裝具體代碼,供大家參考,具體內(nèi)容如下

未上傳狀態(tài)

上傳狀態(tài)

其他狀態(tài)(查看/刪除)

自定義組件文件名稱 - 這里叫UploadImg.vue

<template>
  <div>
    <el-form>
      <!-- :on-change="uploadFile" -->
      <el-upload
        :limit="limit"   //最大允許上傳個(gè)數(shù)
        action
        accept="image/*" //接受上傳的
        :on-change="uploadFile" //文件狀態(tài)改變時(shí)的函數(shù)
        list-type="picture-card" //文件列表的類型
        :auto-upload="false" //是否在選取文件后立即進(jìn)行上傳
        :file-list="fileList" //虛擬文件數(shù)組
        :on-exceed="handleExceed" //文件超出個(gè)數(shù)限制時(shí)的函數(shù)
        :on-preview="handlePictureCardPreview" //點(diǎn)擊文件列表中已上傳的文件時(shí)的函數(shù)
        :on-remove="handleRemove" //文件列表移除文件時(shí)的函數(shù)
        ref="upload"
        class="avatar-uploader"
        :class="{hide:showUpload}" //用來隱藏到達(dá)limit最大值之后 關(guān)閉上傳按鈕
        :disabled="disabled" //為查看不能上傳進(jìn)行處理
      >
        <i class="el-icon-plus"></i>
      </el-upload>
      //查看圖片
      <el-dialog width="30%" :visible.sync="dialogVisible">
        <img width="100%" :src="imgUrl.url" alt />
      </el-dialog>
      //如果不是需要直接上傳的,而是需要按鈕點(diǎn)擊再進(jìn)行圖片上傳請(qǐng)打開此方法
      //上面的el-upload標(biāo)簽里on-change換成http-request方法
      <!-- <Button text="上 傳" type="add_u" style="margin-top: 10px;" @click.native="submitUpload"></Button> -->
    </el-form>
  </div>
</template>

<script>
//引入上傳圖片接口
import { uploadImg } from "@/api/public/api";
export default {
  props: {
    limit: Number,
    fileList: Array,
    disabled: Boolean,
  },
  data() {
    return {
      showUpload: false, //控制limit最大值之后 關(guān)閉上傳按鈕
      dialogVisible: false, //查看圖片彈出框
      imgUrl: [], //上傳圖片后地址合集
    };
  },
  //監(jiān)聽上傳圖片的數(shù)組(為了處理修改時(shí),自動(dòng)渲染問題,和上傳按鈕消失問題);
  watch: {
    fileList(newName, oldName) {
      if (newName.length == this.limit) this.showUpload = true;
      else this.showUpload = false;
    },
  },
  methods: {
    //文件列表移除文件時(shí)的函數(shù)
    handleRemove(file, fileList) {
      const index = this.fileList.findIndex((item) => item === file.uid);
      this.imgUrl.splice(index, 1);
      this.$emit("delUrl", this.imgUrl);
      if (fileList.length < this.limit) this.showUpload = false;
    },
    //點(diǎn)擊文件列表中已上傳的文件時(shí)的函數(shù)
    handlePictureCardPreview(file) {
      this.imgUrl.url = file.url;
      this.dialogVisible = true;
    },
    //這里是不需要直接上傳而是通過按鈕上傳的方法
    submitUpload() {
      this.$refs.upload.submit();
    },
    //文件狀態(tài)改變時(shí)的函數(shù)(主要邏輯函數(shù))
    uploadFile(e, fileList) {
      //判斷用戶上傳最大數(shù)量限制,來讓上傳按鈕消失
      if (fileList.length >= this.limit) this.showUpload = true;
      // const file = e.file; <- 這里是不需要直接上傳而是通過按鈕上傳的
      const file = e.raw; // <- 這里是直接上傳的
      //大小
      const size = file.size / 1024 / 1024 / 2;
      if (
        !(
          file.type === "image/png" ||
          file.type === "image/gif" ||
          file.type === "image/jpg" ||
          file.type === "image/jpeg"
        )
      ) {
        this.$notify.warning({
          title: "警告",
          message:
            "請(qǐng)上傳格式為image/png, image/gif, image/jpg, image/jpeg的圖片",
        });
      } else if (size > 2) {
        this.$notify.warning({
          title: "警告",
          message: "圖片大小必須小于2M",
        });
      } else {
        if (this.limit == 1) this.imgUrl = []; //此處判斷為一張的時(shí)候需要清空數(shù)組
        const params = new FormData();
        params.append("source", file);
        uploadImg(params).then((res) => {
        //這里返回的數(shù)據(jù)結(jié)構(gòu)(根據(jù)自己返回結(jié)構(gòu)進(jìn)行修改)
          if (res.data.status === 1) {
            this.$message.success("上傳成功");
            this.imgUrl = res.data;
            //調(diào)用父組件的方法來傳遞圖片參數(shù)
            this.$emit("getUrl", this.imgUrl);
          } else this.$message.error("上傳失敗");
        });
      }
    },
    //文件超出個(gè)數(shù)限制時(shí)的函數(shù)
    handleExceed(files, fileList) {
      this.$message.info(`最多只允許上傳${this.limit}張圖片`);
    },
  },
};
</script>

//這里修改上傳前后的樣式(我覺得el-upload不好看 也可以自行修改)
<style  scope>
.hide .el-upload--picture-card {
  display: none !important;
}
.avatar-uploader > .el-upload {
  width: 200px;
  height: 200px;
  line-height: 200px;
  border-radius: 0px;
  background: #fff;
  border: 1px dashed #ccc;
}
.avatar-uploader > .el-upload > i {
  font-size: 28px;
  color: #ccc;
}
.avatar-uploader > .el-upload-list {
  display: block;
}
.avatar-uploader > .el-upload-list > .el-upload-list__item {
  width: 200px;
  height: 200px;
  display: block;
}
.avatar-uploader > .el-upload-list > .el-upload-list__item > img {
  width: 200px;
  height: 200px;
  border-radius: 0px;
}
</style>

在頁面中使用 - (因?yàn)槲疫@邊用的地方比較多,我就寫全局了,你們可以根據(jù)自身項(xiàng)目來決定)

main.js

//圖片上傳組件
import UploadImg from "@/views/common/UploadImg.vue";
Vue.component('UploadImg', UploadImg)

demo.vue

<el-form-item label="上傳圖片">
 //limit 最大上傳幾張圖片  //fileList 圖片數(shù)組   //getUrl 獲取上傳后地址 //delUrl 刪除上傳后地址  // disabled 禁用處理
  <UploadImg :limit="1" :file-list="fileList" @getUrl="getUrl($event,'自己需要攜帶的參數(shù)')" @delUrl="delUrl($event,'自己需要攜帶的參數(shù)')" :disabled="true" />
</el-form-item>

//變量聲明
data:{
 fileList:[]
 }
//函數(shù)
getUrl(getUrl){
 console.log(getUrl)
 };
delUrl(getUrl){
console.log(getUrl)
};

希望此文章能幫助到你!!

以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • Vue-cli項(xiàng)目獲取本地json文件數(shù)據(jù)的實(shí)例

    Vue-cli項(xiàng)目獲取本地json文件數(shù)據(jù)的實(shí)例

    下面小編就為大家分享一篇Vue-cli項(xiàng)目獲取本地json文件數(shù)據(jù)的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • 淺談Vue2.4.0 $attrs與inheritAttrs的具體使用

    淺談Vue2.4.0 $attrs與inheritAttrs的具體使用

    這篇文章主要介紹了淺談Vue2.4.0 $attrs與inheritAttrs的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-03-03
  • vue el-tree 默認(rèn)展開第一個(gè)節(jié)點(diǎn)的實(shí)現(xiàn)代碼

    vue el-tree 默認(rèn)展開第一個(gè)節(jié)點(diǎn)的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue el-tree 默認(rèn)展開第一個(gè)節(jié)點(diǎn)的實(shí)現(xiàn)代碼,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-05-05
  • vue3前端實(shí)現(xiàn)全屏顯示及元素垂直填滿頁面效果

    vue3前端實(shí)現(xiàn)全屏顯示及元素垂直填滿頁面效果

    這篇文章主要給大家介紹了關(guān)于vue3前端實(shí)現(xiàn)全屏顯示及元素垂直填滿頁面效果的相關(guān)資料,文中還給大家介紹了vue3實(shí)現(xiàn)某一個(gè)元素全屏之后就黑屏了的解決辦法,需要的朋友可以參考下
    2024-02-02
  • vue實(shí)現(xiàn)旋轉(zhuǎn)木馬動(dòng)畫

    vue實(shí)現(xiàn)旋轉(zhuǎn)木馬動(dòng)畫

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)旋轉(zhuǎn)木馬動(dòng)畫,圖片數(shù)量無限制,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-07-07
  • SpringBoot+Vue3實(shí)現(xiàn)上傳文件功能

    SpringBoot+Vue3實(shí)現(xiàn)上傳文件功能

    這篇文章主要介紹了SpringBoot+Vue3實(shí)現(xiàn)上傳文件功能,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-01-01
  • vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法

    vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法

    這篇文章主要介紹了vue router嵌套路由在history模式下刷新無法渲染頁面問題的解決方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-01-01
  • 解決vue中的無限循環(huán)問題

    解決vue中的無限循環(huán)問題

    這篇文章主要介紹了解決vue中的無限循環(huán)問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • Vue頁面骨架屏注入方法

    Vue頁面骨架屏注入方法

    這篇文章主要介紹了Vue頁面骨架屏注入的操作,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • Vue2 配置 Axios api 接口調(diào)用文件的方法

    Vue2 配置 Axios api 接口調(diào)用文件的方法

    本篇文章主要介紹了Vue2 配置 Axios api 接口調(diào)用文件的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-11-11

最新評(píng)論