Edit in JSFiddle

 // by https://github.com/promosis/file-upload-with-preview
 // 
 
 (function(global, factory) {
    typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() : typeof define === 'function' && define.amd ? define(factory) : (global.FileUploadWithPreview = factory());
}(this, (function() {
    'use strict';

    var _createClass = function() {
        function defineProperties(target, props) {
            for (var i = 0; i < props.length; i++) {
                var descriptor = props[i];
                descriptor.enumerable = descriptor.enumerable || false;
                descriptor.configurable = true;
                if ("value" in descriptor) descriptor.writable = true;
                Object.defineProperty(target, descriptor.key, descriptor);
            }
        }
        return function(Constructor, protoProps, staticProps) {
            if (protoProps) defineProperties(Constructor.prototype, protoProps);
            if (staticProps) defineProperties(Constructor, staticProps);
            return Constructor;
        };
    }();

    function _classCallCheck(instance, Constructor) {
        if (!(instance instanceof Constructor)) {
            throw new TypeError("Cannot call a class as a function");
        }
    }

    var FileUploadWithPreview = function() {
        function FileUploadWithPreview(uploadId) {
            _classCallCheck(this, FileUploadWithPreview);

            if (!uploadId) {
                throw new Error('No uploadId found. You must initialize file-upload-with-preview with a unique uploadId.');
            }

            //Set initial variables
            this.uploadId = uploadId;
            this.cachedFileArray = [];

            //Grab the custom file container elements
            this.el = document.querySelector('.custom-file-container[data-upload-id="' + this.uploadId + '"]');
            if (!this.el) {
                throw new Error('Could not find a `custom-file-container` with the id of: ' + this.uploadId);
            }
            this.input = this.el.querySelector('input[type="file"]');
            this.inputLabel = this.el.querySelector('.custom-file-container__custom-file__custom-file-control');
            this.imagePreview = this.el.querySelector('.custom-file-container__image-preview');
            this.clearButton = this.el.querySelector('.custom-file-container__image-clear');

            //Make sure all elements have been attached
            if (!this.el || !this.input || !this.inputLabel || !this.imagePreview || !this.clearButton) {
                throw new Error('Cannot find all necessary elements. Please make sure you have all the necessary elements in your html for the id: ' + this.uploadId);
            }

            //Set the base64 background images
            this.baseImage = '';
            this.successPdf = '';
            this.successVideo = '';
            this.successFileAlt = '';
            this.successMultiple = '';

            //Set click events
            this.bindClickEvents();
        }

        _createClass(FileUploadWithPreview, [{
            key: 'bindClickEvents',
            value: function bindClickEvents() {
                var _this2 = this;

                //Grab the current instance
                var self = this;

                //Let's set the placeholder image
                this.imagePreview.style.backgroundImage = 'url("' + this.baseImage + '")';

                //Deal with the change event on the input
                this.input.addEventListener('change', function() {
                    var _this = this;

                    var selectedFilesCount = this.files.length;

                    //In this case, the user most likely had hit cancel - which does something
                    //a little strange if they had already selected a single or multiple images -
                    //it acts like they now have *no* files - which isn't true. We'll just check here
                    //for any cached images already captured, and proceed normally. If something *does* want
                    //to clear their images, they'll use the clear button on the label we provide.
                    if (selectedFilesCount === 0) {
                        return;
                    }

                    //The first thing we want to do is clear whatever
                    //we already have saved in self.cachedFileArray, as they are overwriting that now. The logic is that their
                    //latest selection should be the one we listen to.
                    self.cachedFileArray = [];

                    //Let's loop through the selected images

                    var _loop = function _loop(x) {
                        //Grab this index's file
                        var file = _this.files[x];

                        //File/files selected.
                        self.cachedFileArray.push(file);
                        var reader = new FileReader();
                        reader.readAsDataURL(file);

                        reader.onload = function(e) {
                            //If more than one file was selected show a special input label and image
                            if (selectedFilesCount > 1) {
                                self.inputLabel.innerHTML = selectedFilesCount + ' files selected';
                                self.imagePreview.style.backgroundImage = 'url("' + self.successMultiple + '")';
                                return;
                            }

                            //A single file was selected...
                            self.inputLabel.innerHTML = file.name;

                            //If png or jpg/jpeg, use the actual image
                            if (file.type.match('image/png') || file.type.match('image/jpeg')) {
                                self.imagePreview.style.backgroundImage = 'url("' + reader.result + '")';
                            } else if (file.type.match('application/pdf')) {
                                //PDF Upload
                                self.imagePreview.style.backgroundImage = 'url("' + self.successPdf + '")';
                            } else if (file.type.match('video/*')) {
                                //Video upload
                                self.imagePreview.style.backgroundImage = 'url("' + self.successVideo + '")';
                            } else {
                                //Everything else
                                self.imagePreview.style.backgroundImage = 'url("' + self.successFileAlt + '")';
                            }
                        };
                    };

                    for (var x = 0; x < this.files.length; x++) {
                        _loop(x);
                    }
                }, true);

                //Listen for the clear button
                this.clearButton.addEventListener('click', function() {
                    _this2.clearPreviewImage();
                }, true);
            }
        }, {
            key: 'clearPreviewImage',
            value: function clearPreviewImage() {
                this.input.value = '';
                this.inputLabel.innerHTML = '';
                this.imagePreview.style.backgroundImage = 'url("' + this.baseImage + '")';
                this.cachedFileArray = [];
            }
        }]);

        return FileUploadWithPreview;
    }();

    return FileUploadWithPreview;

})));
   
   //First upload
            var firstUpload = new FileUploadWithPreview('myFirstImage')
            var firstUploadInfoButton = document.querySelector('.upload-info-button--first');
            firstUploadInfoButton.addEventListener('click', function(){
                console.log('First upload:', firstUpload, firstUpload.cachedFileArray);
            })

.custom-file-container {
    box-sizing: border-box;
    position: relative;
    display: block;
}

.custom-file-container__custom-file {
    box-sizing: border-box;
    position: relative;
    display: inline-block;
    width: 100%;
    height: calc(2.25rem + 2px);
    margin-bottom: 0;
    margin-top: 5px;
}

.custom-file-container__custom-file:hover {
    cursor: pointer;
}

.custom-file-container__custom-file__custom-file-input {
    box-sizing: border-box;
    min-width: 14rem;
    max-width: 100%;
    height: calc(2.25rem + 2px);
    margin: 0;
    opacity: 0;
}

.custom-file-container__custom-file__custom-file-control {
    box-sizing: border-box;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    z-index: 5;
    height: calc(2.25rem + 2px);
    padding: .5rem .75rem;
    overflow: hidden;
    line-height: 1.5;
    color: #333;
    user-select: none;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #c0c0af;
    border-radius: .25rem;
}

.custom-file-container__custom-file__custom-file-control:empty::after {
    box-sizing: border-box;
    content: "選択されていません";
}

.custom-file-container__custom-file__custom-file-control::before {
    box-sizing: border-box;
    position: absolute;
    top: 0;
    right: 0;
    z-index: 6;
    display: block;
    height: calc(2.25rem + 2px);
    padding: .5rem .75rem;
    line-height: 1.25;
    color: #333;
    background-color: #EDEDE8;
    border-left: 1px solid #c0c0af;
}

.custom-file-container__custom-file__custom-file-control::before {
    box-sizing: border-box;
    content: "ファイルを選択";
}

.custom-file-container__image-preview {
    box-sizing: border-box;
    transition: all 0.6s ease;
    margin-top: 20px;
    margin-bottom: 40px;
    height: 250px;
    width: 100%;
    border-radius: 4px;
    background-size: cover;
    background-position: center center;
    background-repeat: no-repeat;
}

html {
                position: relative;
                min-height: 100%;
            }

            body {
                width: 100%;
                height: 100%;
                color: #333;
                font-family: 'Montserrat', sans-serif;
                font-size: 1rem;
                line-height: 1.5;
                margin: 0;
            }

            a {
                color: #4ea2f5;
                text-decoration: none;
            }

            a:hover {
                color: #3f7ebd;
            }

            /*Pre, Code*/

            pre {
                font-family: SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace
            }

            pre {
                padding: .2rem .4rem;
                font-size: 90%;
                color: #333;
                background-color:#EDEDE8;
                border-radius: .25rem
            }

            /*Header*/

            .header-container {
                margin-top: 30px;
                padding-left: 10px;
                padding-right: 10px;
                display: flex;
                flex-direction: column;
                align-items: center;
            }

            .header-container__header-image {
                max-width: 100%;
                max-height: 60px;
                margin-bottom: 30px;
            }

            .header-container__header-content {
                font-size: 2.5rem;
                margin-bottom: 30px;
                margin-top: 0;
                text-align: center;
            }

            .header-container__code {
                margin-bottom: 10px;
            }

            /*Upload Container*/

            .demo-upload-container {
                padding: 50px 10px;
                margin-left: auto;
                margin-right: auto;
                max-width: 1000px;
                position: relative;
                display: flex;
                flex-direction: row;
                justify-content: space-around;
                flex-wrap: wrap;
            }

            /*Info Container*/

            .demo-info-container {
                margin-left: auto;
                margin-right: auto;
                margin-bottom: 40px;
                max-width: 300px;
                position: relative;
                display: flex;
                flex-direction: row;
                justify-content: space-around;
                flex-wrap: wrap;

                background: #4ea2f5;
                padding: 15px 15px;
                border-radius: 6px;
                text-align: center;
                color: white;
            }

            .demo-info-container a {
                color: white;
                text-decoration: underline;
            }

            .demo-info-container a:hover {
                color: #eee;
            }

            .upload-info-button {
                display: block;
                margin-bottom: 10px;
            }
 <div class="demo-upload-container">

            <div class="custom-file-container" data-upload-id="myFirstImage">
                <label>画像を選択してください <a href="javascript:void(0)" class="custom-file-container__image-clear" title="Clear Image"> xキャンセル</a></label>
                <label class="custom-file-container__custom-file" >
                    <input type="file" class="custom-file-container__custom-file__custom-file-input" accept="image/*">
                    <input type="hidden" name="MAX_FILE_SIZE" value="10485760" />
                    <span class="custom-file-container__custom-file__custom-file-control"></span>
                </label>
                <div class="custom-file-container__image-preview"></div>
            </div>
        </div>