Можно ли проверить размер и расширение файла перед загрузкой одновременно? - PullRequest
1 голос
/ 25 апреля 2019

Мне удалось проверить расширение файла с помощью jquery, но когда я попытался проверить размер файла, у меня возникла проблема с тем, что мой код не работает.

Я использую новейшую версию jquery.

КОД ВАЛИДАЦИИ ФАЙЛА РАСШИРЕНИЯ И РАЗМЕРА ПРОБЛЕМЫ ЗДЕСЬ:

(function($) {$.fn.checkFileType = function(options) {
                var defaults = {
                    allowedExtensions: [],
                    success: function() {},
                    error: function() {}
                };
                options = $.extend(defaults, options);

                return this.each(function() { 

                    $(this).on('change', function() {
                        var value = $(this).val(),
                        file = value.toLowerCase(),
                        extension = file.substring(file.lastIndexOf('.') + 1);

                        if ($.inArray(extension, options.allowedExtensions) == -1) {
                            options.error();
                            $(this).focus();
                        } else {
                            options.success();

                        }

                    });

                    $(this).on('change', function() { //its wrong ?
                        var size = $(this).files[0].size,

                        if (size <= 200) { 
                            options.success();
                        } else {
                            options.error();
                            $(this).focus();

                        }

                    });

                });
            };

        })(jQuery);
        $(function() {
            $('#upload_file').checkFileType({ // here is input file 
                allowedExtensions: ['jpg', 'jpeg'],
                success: function() {
                    $("#alert").html("File allowed Extensions : jpg or jpeg").show().fadeOut(5000);
                },
                error: function() {
                    $("#alert").html("Please upload file with jpg or jpeg and 200kb maximum size ").show().fadeOut(5000);
                    var $el = $('#upload_file');
                    $el.wrap('<form>').closest('form').get(0).reset();
                    $el.unwrap();
                }
            });

        });

КОД ВАЛИДАЦИИ ФАЙЛА РАСШИРЕНИЯ УСПЕХА ЗДЕСЬ:

        (function($) {
            $.fn.checkFileType = function(options) {
                var defaults = {
                    allowedExtensions: [],
                    success: function() {},
                    error: function() {}
                };
                options = $.extend(defaults, options);

                return this.each(function() {

                    $(this).on('change', function() {
                        var value = $(this).val(),
                        file = value.toLowerCase(),
                        extension = file.substring(file.lastIndexOf('.') + 1);

                        if ($.inArray(extension, options.allowedExtensions) == -1) {
                            options.error();
                            $(this).focus();
                        } else {
                            options.success();

                        }

                    });

                });
            };

        })(jQuery);
        $(function() {
            $('#upload_file').checkFileType({ // here is input file 
                allowedExtensions: ['jpg', 'jpeg'],
                success: function() {
                    $("#alert").html("File allowed Extensions : jpg or jpeg").show().fadeOut(5000);
                },
                error: function() {
                    $("#alert").html("Please upload file with jpg or jpeg and 200kb maximum size ").show().fadeOut(5000);
                    var $el = $('#upload_file');
                    $el.wrap('<form>').closest('form').get(0).reset();
                    $el.unwrap();
                }
            });

        });

Ответы [ 2 ]

2 голосов
/ 25 апреля 2019

Когда вы выбираете файл в диалоге выбора файлов, вы получаете объект массива файлов. Этот объект имеет информацию о файле. Вы можете получить доступ к одному файлу, как.

this.files [0]

Для доступа к размеру. Вы можете использовать

this.files [0] .size.

1 голос
/ 25 апреля 2019

Я вижу, что идеальный ответ, на который вы ссылаетесь, - это проверка только расширения файла.Так что все происходит правильно, поэтому, чтобы проверить размер файла @client side в jquery, вы можете сделать это:

 if(this.files[0].size > 2000000) {
   alert("Please upload file less than 2MB. Thanks!!");
   $(this).val('');
 }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...