Heim Web-Frontend js-Tutorial Beispiel für ein jQuery-Plug-in, das die Größe und das Format der hochgeladenen Dateien begrenzt_jquery

Beispiel für ein jQuery-Plug-in, das die Größe und das Format der hochgeladenen Dateien begrenzt_jquery

May 16, 2016 pm 04:18 PM
jquery 上传文件 大小 插件 格式 限制

Das Beispiel in diesem Artikel beschreibt das jQuery-Plug-in, das die Größe und das Format hochgeladener Dateien begrenzt. Teilen Sie es als Referenz mit allen. Die spezifische Analyse lautet wie folgt:

Beim Hochladen von Dateien auf den Client ist es normalerweise erforderlich, die Größe und das Format der Datei zu begrenzen. Die häufigste Methode ist die Verwendung eines bestimmten Plug-Ins. Einige ausgereifte Plug-Ins verfügen über schöne Schnittstellen und leistungsstarke Funktionen. Der einzige Nachteil ist jedoch, dass manchmal Probleme mit der Browserkompatibilität auftreten. In diesem Artikel schreiben wir ein „originales“ jQuery-Plug-in, das die Größe und das Format hochgeladener Dateien begrenzen kann.

Schreiben Sie zunächst ein Plug-In mit dem Namen checkFileTypeAndSize.js. Begrenzen Sie das Dateiformat, indem Sie beurteilen, ob der Suffixname der aktuellen Datei in dem von der Voreinstellung zugelassenen Suffixnamen-Array enthalten ist, indem Sie beurteilen, ob die Größe der aktuellen Datei unter IE und anderen Browsern größer als die von der Voreinstellung zulässige maximale Dateigröße ist voreingestellt, um die Dateigröße zu begrenzen und Rückruffunktionen für Formatfehler, Überschreitung der Grenzgröße und Erfüllung von Bedingungen bereitzustellen.

Code kopieren Der Code lautet wie folgt:
(Funktion ($) {
$.fn.checkFileTypeAndSize = Funktion (Optionen) {
//Standardeinstellungen
      var defaults = {
              erlaubte Erweiterungen: [],
                 maxSize: 1024, // Die Einheit ist KB, die standardmäßige maximale Dateigröße beträgt 1 MB = 1024 KB
Erfolg: function () { },
              extensionerror: function () { },
sizeerror: function () { }
        };
//Einstellungen zusammenführen
Optionen = $.extend(Standards, Optionen);
//Elemente durchqueren
          return this.each(function () {
                 $(this).on('change', function () {
//Dateipfad abrufen
              var filePath = $(this).val();
//Dateipfad in Kleinbuchstaben
              var fileLowerPath = filePath.toLowerCase();
//Erhalte den Suffixnamen der Datei
            var extension = fileLowerPath.substring(fileLowerPath.lastIndexOf('.') 1);
//Bestimmen Sie, ob der Suffixname im voreingestellten und zulässigen Suffixnamen-Array enthalten ist
If ($.inArray(extension, options.allowedExtensions) == -1) {
options.extensionerror();
                            $(this).focus();
                     } sonst {
                     versuchen Sie es mit {
                        var size = 0;
Wenn ($.browser.msie) {//dh alte Browserversion
                                                         var fileMgr = new ActiveXObject("Scripting.FileSystemObject");
                                                                                  var fileObj = fileMgr.getFile(filePath);
size = fileObj.size; //byte
size = size / 1024;//kb
//size = size / 1024;//mb
                                  } else {//Andere Browser
size = $(this)[0].files[0].size;//byte
size = size / 1024;//kb
//size = size / 1024;//mb
                                                                                                       } If (size > options.maxSize) {
options.sizeerror();
                            } else {
options.success();
                                                                                                       }                                  } Catch (e) {
alarm("Fehler: "e);
                 }
                }
            });
        });
};
})(jQuery);

Der Anruf beim Kunden wird sehr einfach.


Code kopieren Der Code lautet wie folgt:<input type="file" name="f" id= „f“ />
@section-Skripte
{
<script src="~/Scripts/checkFileTypeAndSize.js"></script>
<script type="text/javascript">
          $(function() {
                 $('#f').checkFileTypeAndSize({
                                                                                                                                                                                                                                         erlaubte Erweiterungen: ['jpg'],
                    maxSize: 10,
Erfolg: function() {
alarm('ok');
                 },
Erweiterungsfehler: function() {
warning('Erlaubtes Format ist: jpg');
                    zurück;
                 },
sizeerror: function() {
warning('Maximale Größe 10 KB');
                    zurück;
                }
            });
        });
</script>
}

Ich hoffe, dass dieser Artikel für alle bei der jQuery-Programmierung hilfreich sein wird.
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung? Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung? Mar 08, 2024 am 08:55 AM

Was ist das Installationsverzeichnis der Chrome-Plug-in-Erweiterung?

So erhöhen Sie die Festplattengröße in VirtualBox [Anleitung] So erhöhen Sie die Festplattengröße in VirtualBox [Anleitung] Mar 17, 2024 am 10:10 AM

So erhöhen Sie die Festplattengröße in VirtualBox [Anleitung]

Wie entferne ich Kommentarbeschränkungen für ein Videokonto? Wie hoch ist die Wortbeschränkung für Kommentare zu einem Videokonto? Wie entferne ich Kommentarbeschränkungen für ein Videokonto? Wie hoch ist die Wortbeschränkung für Kommentare zu einem Videokonto? Mar 22, 2024 pm 02:11 PM

Wie entferne ich Kommentarbeschränkungen für ein Videokonto? Wie hoch ist die Wortbeschränkung für Kommentare zu einem Videokonto?

Teilen Sie drei Lösungen mit, warum der Edge-Browser dieses Plug-in nicht unterstützt Teilen Sie drei Lösungen mit, warum der Edge-Browser dieses Plug-in nicht unterstützt Mar 13, 2024 pm 04:34 PM

Teilen Sie drei Lösungen mit, warum der Edge-Browser dieses Plug-in nicht unterstützt

Wie verwende ich die PUT-Anfragemethode in jQuery? Wie verwende ich die PUT-Anfragemethode in jQuery? Feb 28, 2024 pm 03:12 PM

Wie verwende ich die PUT-Anfragemethode in jQuery?

jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite Feb 28, 2024 pm 09:06 PM

jQuery-Tipps: Ändern Sie schnell den Text aller a-Tags auf der Seite

Was soll ich tun, wenn die maximale Größe der Dokumente, die WPS-Mitglieder hochladen können, das Limit überschreitet? Was soll ich tun, wenn die maximale Größe der Dokumente, die WPS-Mitglieder hochladen können, das Limit überschreitet? Mar 20, 2024 pm 06:40 PM

Was soll ich tun, wenn die maximale Größe der Dokumente, die WPS-Mitglieder hochladen können, das Limit überschreitet?

Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern Feb 28, 2024 pm 05:42 PM

Verwenden Sie jQuery, um den Textinhalt aller a-Tags zu ändern

See all articles