Author: HelloGitHub- Kalifun

This is HelloGitHub launched “explain open source project” series, today I recommend a JavaScript open source file upload library project — FilePond

Introduce a,

1.1 FilePond

It is a JavaScript file upload library. Upload files can be dragged in, and images are optimized to speed up the upload. Make the user experience excellent, progress visible, silky smooth user experience.

FilePond project address: github.com/pqina/filep…

1.2 Features and Advantages

  • Upload content: supports directories, files, multiple files, local paths, and remote urls.
  • File management: Delete files, select files, copy and paste files, or add files using APIS.
  • Upload method: upload asynchronously using AJAX, or encode files as Base64 and send data as a form.
  • Image optimization: Automatically adjusts image size, cropping and fixes EXIF orientation.
  • Responsive: Available on mobile and desktop devices.

Look at the effect drawing and function introduction, is not some hand itch. Next is the actual combat operation part, we can follow the article step by step to use this library, light up your file upload skills point!

Two, actual combat operation

Here we walk you through how to use the FilePond library step by step. We used the simplest CDN reference method so that people could quickly check its charm (copy the code to see the effect), then went into depth to explain the function of each plug-in, and finally wrote a combination of several plug-ins and the effect demonstration.

Tips: Explanations are presented in the code in the form of comments, please pay attention to read.

2.1 Quick Use (CDN)

Sample code:


      
<html>
<head>
    <! -- HTML title -->
    <title>FilePond from CDN</title>

    <! -- Introducing Filepond CSS -->
    <link href="https://unpkg.com/filepond/dist/filepond.css" rel="stylesheet">

</head>
<body>

<! -- Input tag as file upload entry -->
<input type="file" class="filepond">

<! -- Add FilePond js -->
<script src="https://unpkg.com/filepond/dist/filepond.js"></script>


<script>
  Parse uses the class. FilePond parses the given parts of the DOM tree and converts them to FilePond elements.
  FilePond.parse(document.body);

</script>

</body>
</html>
Copy the code

Display effect:

2.2 Introducing Plug-ins

As if uploading alone is not enough for our needs, FilePond has a diverse and powerful section of plug-ins that can be combined according to your needs. Here’s a quick look at what each plug-in does:

  • File Rename: Renames a File on a client
  • File Encode: Encodes files as Base64 data
  • File Size Validation: a File size Validation tool
  • File Type Validation: File Type Validation tool
  • File Metadata: Limits the type of File to be added
  • File Poster: Displays images in a File project
  • Image Preview: Shows a Preview of an Image file
  • Image Edit: Manually Edit an Image file
  • Image Crop: Sets the cropping scale of the Image file
  • Image Resize: Sets the output size of the Image file
  • Image Transform: Image Transform on the client before uploading
  • Image EXIF Orientation: Extract EXIF Orientation information
  • Image Size Validation: Limits the Size of the Image to be added
  • Image Filter: Apply the color matrix to the Image pixels

Let me show you how to introduce plug-ins.

The pit!

<head>
  <! -- Introducing image preview plugin CSS file -->
  <link href="https://unpkg.com/filepond-plugin-image-preview/dist/filepond-plugin-image-preview.css" rel="stylesheet">
</head>
<! Image preview plugin js file -->
<script src="https://unpkg.com/filepond-plugin-image-preview/dist/filepond-plugin-image-preview.js"></script>

<script>

/ / registered FilePondPluginImagePreview image preview plugin is uploaded images and to reduce the preview.
FilePond.registerPlugin(FilePondPluginImagePreview);
</script>
Copy the code

Let’s walk through the steps for introducing plug-ins:

  1. Introduce CSS files (some plug-ins have CSS files)
  2. Importing JS files
  3. To register the plugin
  4. Configure plug-ins (some plug-ins need to be configured)

2.3 Used with plug-ins

Complete sample code:


      
<html>
<head>
    <title>FilePond from CDN</title>

    <! -- Filepond CSS -->
    <link href="https://unpkg.com/filepond/dist/filepond.css" rel="stylesheet">
    <! - FilePondPluginImagePreview plugin CSS - >
    <link href="https://unpkg.com/filepond-plugin-image-preview/dist/filepond-plugin-image-preview.css" rel="stylesheet">
    <! -- FilePondPluginImageEdit plugin CSS-->
    <link href="https://unpkg.com/filepond-plugin-image-edit/dist/filepond-plugin-image-edit.css" rel="stylesheet">
</head>

<body>

<! We will change this input box to upload file box -->
<input type="file" class="filepond">

<! - FilePondPluginImagePreview plug-in js - >
<script src="https://unpkg.com/filepond-plugin-image-preview/dist/filepond-plugin-image-preview.js"></script>
<! - FilePondPluginImageEdit plug-in js - >
<script src="https://unpkg.com/filepond-plugin-image-edit/dist/filepond-plugin-image-edit.js"></script>
<! - FilePondPluginFileValidateSize plug-in js - >
<script src="https://unpkg.com/filepond-plugin-file-validate-size/dist/filepond-plugin-file-validate-size.js"></script>
<! - FilePondPluginFileValidateType plug-in js - >
<script src="https://unpkg.com/filepond-plugin-file-validate-type/dist/filepond-plugin-file-validate-type.js"></script>
<! - FilePondPluginImageCrop plug-in js - >
<script src="https://unpkg.com/filepond-plugin-image-crop/dist/filepond-plugin-image-crop.js"></script>
<! - FilePondPluginImageExifOrientation plug-in js - >
<script src="https://unpkg.com/filepond-plugin-image-exif-orientation/dist/filepond-plugin-image-exif-orientation.js"></script>
<! -- Add Filepond js-->
<script src="https://unpkg.com/filepond/dist/filepond.js"></script>

<script>
    The querySelector() method returns an element in the document that matches the specified CSS selector.
    var inputElement = document.querySelector('input[type="file"]');

    // Register the plug-in
    / / FilePondPluginImagePreview upload can preview to upload pictures, etc
    // FilePondPluginImageEdit Is not demonstrated because doka charges for it.
    / / FilePondPluginFileValidateType image type
    // FilePondPluginImageCrop image clipping
    / / FilePondPluginFileValidateSize validation plug-in processing block is too large to the size of the file.
    FilePond.registerPlugin(
        FilePondPluginImagePreview,
        FilePondPluginImageEdit,
        FilePondPluginFileValidateSize,
        FilePondPluginImageCrop,
        FilePondPluginFileValidateType,
        FilePondPluginImageExifOrientation

    );

    FilePond.setOptions({
        // Setting a single URL is the most basic form of defining the server configuration.
        server: '/upload'.// Set the image type to PNG
        allowFileTypeValidation: false.acceptedFileTypes: "image/jpg".// Enable or disable image cropping
        allowImageCrop: true.// Enable or disable file size validation
        allowFileSizeValidation: true.maxFileSize: null.// Enable or disable extracting EXIF information
        allowImageExifOrientation: true

    });

    // Step up the base file input to the FilePond element using the create method.
    FilePond.create(inputElement)
</script>

</body>
</html>
Copy the code

The example above shows the method of a common FilePond plug-in, which looks like this:

Of course, there are other methods such as:

  • Destroys: an instance
  • Find: Returns an instance of the supplied element appended
  • GetOptions: Returns the current configuration items
  • Supported: Checks whether the browser supports FilePond

I’m not going to go through the whole thing here, but if you’re interested, you can try it out on your own.

Third, summary

That’s it, FilePond is a lightweight upload plugin. There aren’t too many tedious configurations, and INSTEAD of demonstrating each plug-in introduction, I just show the common ones. Pay attention to the above tips, master the above explained method, other plug-ins you can learn by yourself.

FilePond is a great JavaScript library to check out if you want to quickly add uploads to your website.

Iv. Reference materials

  • FilePond official documentation
  • FilePond Plugins List

Welcome to follow the HelloGitHub official account for more information and content of open source projects

“Explain Open Source project series” launched — let the people who are interested in open source project no longer fear, let the initiator of open source project no longer feel lonely. Follow along as you discover the joys of programming, use, and how easy it is to get involved in open source projects. Welcome to contact us to contribute to us, so that more people fall in love with open source, open source contribution ~