Detailed explanation of JavaScript upload file limit parameter case

Detailed explanation of JavaScript upload file limit parameter case

Project scenario:

1. Upload file restrictions

Function:

1. Prevent front-end operations from uploading abnormal files
2. Limit the rules that meet the requirements and optimize the display model

Functionality:

1. Get the file instance
2. Execute verification rule method

The code is as follows:

//Size limit checkFileSize(file, rules) {
    return new Promise((resolve, reject) => {
        file.size / 1024 / 1024 > rules ? reject() : resolve()
    }).then(
        () => {
          return true
        },
        () => {
			//Operation prompt return Promise.reject()
        }
    )
},
//Upload format restrictions checkFileType(file, rules) {
    return new Promise((resolve, reject) => {
        rules && rules.includes(file.type) ? resolve() : reject()
    }).then(
      () => {
          return true
      },
      () => {
          //Operation prompt return Promise.reject()
      }
    )
},
//Aspect ratio (image)
checkImageWH(file, rules) {
    const _this = this
    return new Promise((resolve, reject) => {
    	//Read file const filereader = new FileReader()
        filereader.readAsDataURL(file)
        filereader.onload = e => {
          const src = e.target.result
          const image = new Image()
          image.onload = function() {
			//Analyze the data and determine whether it complies with the rules resolve()
		}
          image.onerror = reject
          image.src = src
        }
    }).then(
        () => {
          return true
        },
        () => {
          //Operation prompt return Promise.reject()
        }
    )
},
//Aspect ratio (video)
checkVideoWH(file, rules) {
      return new Promise(function(resolve, reject) {
        var url = URL.createObjectURL(file)
        var video = document.createElement('video')
        video.onloadedmetadata = evt => {
          URL.revokeObjectURL(url)
          //Analyze the data and determine whether it complies with the rules resolve()
        }
        video.src = url
        video.load() // fetches metadata
      }).then(
        () => {
          return true
        },
        () => {
          //Operation prompt return Promise.reject()
        }
      )
}

Actual call

//Get the file instance Screen(){
	//Get permission rules const { filesSize, filesFormat, fileLimit} = this // File size, file type, image/video width and height limits //Parameter judgment const isFileSize = filesSize ? await this.checkFileSize(file, filesSize) : true
    const isFileType = filesFormat ? await this.checkFileType(file, filesFormat) : true
	//Picture materialif (fileLimit && fileLimit.type * 1 === 1) {
      const isImageLimit = fileLimit? await this.checkImageWH(file, fileLimit) : true
      //output result return isFileSize && isFileType && isImageLimit
    } else if (fileLimit&& fileLimit.type * 1 === 2) {
    //Video material const isVideoLimit = fileLimit? await this.checkVideoWH(file, fileLimit) : true
      //output result return isFileSize && isFileType && isVideoLimit
    } else {
    //No limit //Output result return isFileSize && isFileType
    }
}

Summary:

1. Get an instance
2. Execution method.

This is the end of this article about the detailed case of JavaScript upload file restriction parameter. For more relevant js upload file restriction parameter content, please search 123WORDPRESS.COM's previous articles or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • Common array operations in JavaScript
  • A simple and in-depth study of async and await in JavaScript
  • JavaScript implementation of classic snake game
  • Javascript basics about built-in objects
  • Detailed explanation of JavaScript operation mechanism and a brief discussion on Event Loop
  • Comparison between Python coroutines and JavaScript coroutines
  • JavaScript to achieve mouse tailing effect
  • JavaScript to achieve simple drag effect
  • Detailed explanation of JavaScript array deduplication
  • JavaScript to implement the aircraft war game
  • JavaScript setinterval delay one second solution
  • A brief talk about JavaScript variable promotion
  • In-depth understanding of JavaScript event execution mechanism
  • 8 essential JavaScript code snippets for your project

<<:  The MySQL server is running with the --read-only option so it cannot execute this statement

>>:  How to Install Xrdp Server (Remote Desktop) on Ubuntu 20.04

Recommend

How to build SFTP server and image server on Linux cloud server

First of all, you can understand the difference b...

Copy and paste is the enemy of packaging

Before talking about OO, design patterns, and the ...

Simple implementation of html hiding scroll bar

1. HTML tags with attributes XML/HTML CodeCopy co...

How to quickly build ELK based on Docker

[Abstract] This article quickly builds a complete...

Introduction to the usage of exists and except in SQL Server

Table of contents 1. exists 1.1 Description 1.2 E...

Serial and parallel operations in JavaScript

Table of contents 1. Introduction 2. es5 method 3...

A brief analysis of event bubbling and event capture in js

Table of contents 01-Event Bubbling 1.1- Introduc...

How to clean up the disk space occupied by Docker

Docker takes up a lot of space. Whenever we run c...

HTML page native VIDEO tag hides the download button function

When writing a web project, I encountered an intr...

Detailed tutorial on installing Prometheus with Docker

Table of contents 1. Install Node Exporter 2. Ins...

Creation, constraints and deletion of foreign keys in MySQL

Preface After MySQL version 3.23.44, InnoDB engin...

MySQL server 5.7.20 installation and configuration method graphic tutorial

This article records the installation and configu...