Vant Uploader implements the component of uploading one or more pictures

Vant Uploader implements the component of uploading one or more pictures

This article shares the Vant Uploader component for uploading one or more pictures for your reference. The specific content is as follows

HTML part

<template>
  <div class="contWrap">
    <van-uploader
      v-model="fileList"
      :multiple="true"
      :before-read="beforeRead"
      :after-read="afterRead"
      :before-delete="delUploadImg"
      upload-icon="plus"
    >
    <!-- Note: This is a custom upload style-->
      <!-- <p>
        <van-icon
          name="plus"
          color="#07c160"
          size=".5rem"
        />
        Upload photo</p> -->
    </van-uploader>
  </div>
</template>

js part

<script>
import axios from "axios";
export default {
  name: "uploadImages",
  data() {
    return {
      fileList: [],
      uploadUrl: "/api/upload/fileUpload",
      headers: {
        token: this.$store.state.account.token,
      },
    };
  },

  methods: {
    // Return Boolean value beforeRead(file) {
      if (file instanceof Array) {
        //Judge whether it is an array file.forEach((v) => {
          this.checkFile(v);
        });
      } else {
        this.checkFile(file);
      }
      return true;
    },
    //Image type checkcheckFile(file) {
      const format = ["jpg", "png", "jpeg"];
      const index = file.name.lastIndexOf(".");
      const finalName = file.name.substr(index + 1);
      if (!format.includes(finalName.toLowerCase())) {
        Toast("Please upload" + format.join(",") + "Format picture");
        return false;
      }
    },
    afterRead(file) {
    // You can upload the file to the server by yourself at this time if (file instanceof Array) {
        file.map((v) => {
          v.status = "uploading";
          v.message = "Uploading...";
          this.uploadImg(v);
        });
      } else {
        file.status = "uploading";
        file.message = "Uploading...";
        this.uploadImg(file);
      }
    },
    //Upload uploadImg(file) {
      const formData = new FormData();
      formData.append("file", file.file);
      axios
        .post(this.uploadUrl, formData, {
          headers: this.headers,
        })
        .then((res) => {
          if (res.data) {
            if (file instanceof Array) {
              //Judge whether it is an array file.map((v, i) => {
                v.status = "success";
                v.message = "";
                v.url = res.data[i];
              });
            } else {
              file.status = "success";
              file.message = "";
              file.url = res.data.uploadUrl;
            }
          }
        })
        .catch((err) => {
          this.$notify({
            type: "warning",
            message: "Upload failed",
          });
        });
    },
    //delete delUploadImg(item) {
      this.fileList = this.fileList.filter((v) => v.url != item.url);
    }
  },
};
</script>

The above is the full content of this article. I hope it will be helpful for everyone’s study. I also hope that everyone will support 123WORDPRESS.COM.

You may also be interested in:
  • The Uploader of Vue+Vant on the mobile terminal realizes the functions of uploading, compressing and rotating pictures
  • Vant uploader implements the drag-and-drop function for uploading pictures (set as cover)

<<:  How to create a view in MySQL

>>:  Steps for restoring a single MySQL table

Recommend

Detailed explanation of the use of MySQL concatenation function CONCAT

The previous articles introduced the replacement ...

CUDA8.0 and CUDA9.0 coexist under Ubuntu16.04

Preface Some of the earlier codes on Github may r...

Docker Tutorial: Using Containers (Simple Example)

If you’re new to Docker, take a look at some of t...

Docker+selenium method to realize automatic health reporting

This article takes the health reporting system of...

Solution to the problem of mysql service starting but not connecting

The mysql service is started, but the connection ...

Web page HTML ordered list ol and unordered list ul

Lists for organizing data After learning so many ...

Convert XHTML CSS pages to printer pages

<br />In the past, creating a printer-friend...

HTML meta explained

Introduction The meta tag is an auxiliary tag in ...

Pitfalls and solutions for upgrading MySQL 5.7.23 in CentOS 7

Preface Recently, I found a pitfall in upgrading ...

What is the function and writing order of the a tag pseudo class

The role of the a tag pseudo-class: ":link&qu...