suchen
HeimWeb-FrontendCSS-TutorialErsetzen Sie JavaScript -Dialoge durch das neue HTML -Dialogfeld

Verabschieden Sie sich vom Dialogfeld JavaScript und nutzen Sie HTML<dialog></dialog> Element! Dieser Artikel zeigt, wie HTML verwendet wird<dialog></dialog> Elemente und JavaScript -Klassen ersetzen elegant traditionelle JavaScript -Dialogfelder ( alert() , confirm() und prompt() ) und verbessern die Benutzererfahrung und -zugrunde.

Ersetzen Sie JavaScript -Dialoge durch das neue HTML -Dialogfeld

Sind Sie müde von diesen monotonen Stilen und begrenzten Funktionen von JavaScript -Dialogen? Obwohl sie bequem sind, haben sie Mängel in Bezug auf Zugänglichkeit, Stilanpassung und Modernisierung. Dieser Artikel bietet eine flexiblere und leistungsfähigere Alternative.

Ich habe API -Aufrufe und JavaScript -Dialoge in einem Projekt stark verwendet, um Benutzer -Feedback zu sammeln. Warten darauf, dass ein anderer Entwickler abgeschlossen ist<modal></modal> Während der Entwicklung der Komponente habe ich alert() , confirm() und prompt() -Funktionen verwendet. Zum Beispiel:

 const Deletelocation = Bestätigung ('Speicherort löschen?');
if (deletelocation) {
  alarm ('Ort gelöscht');
}

Zu diesem Zeitpunkt wurde mir klar, alert() , confirm() und prompt() mit vielen oft übersehenen Modalfensterfunktionen ausgestattet sind:

  1. True Modal Fenster: Immer oben auf dem Stapel, auch in z-index: 99999;<div> Über.<li> <strong>Tastaturzugriff:</strong> Drücken Sie die Eingabetaste, um zu bestätigen. Drücken Sie die Escape, um abbrechen zu können.</li> <li> <strong>Bildschirmleser freundlich:</strong> Fokus bewegen und das Lesen des modalen Fensterinhalts ermöglichen.</li> <li> <strong>Fokuserfassung:</strong> Das Drücken der Registerkarte Taste springt nicht auf fokussierbare Elemente auf der Hauptseite (in Firefox und Safari springt der Fokus auf die UI der Browser.</li> <li> <strong>Unterstützung für Benutzereinstellungen:</strong> Helle und dunkle Modi werden außerhalb der Box unterstützt.</li> <li> <strong>Pause Code Ausführung:</strong> Warten Sie auf Benutzereingaben.</li> <p> Diese JavaScript -Methoden erfüllen meine Bedürfnisse in 99% der Fälle. Warum benutzt ich sie nicht oft? Wahrscheinlich, weil sie wie Systemfehler aussehen und nicht gestylt werden können. Eine weitere wichtige Überlegung ist, dass sie allmählich veraltet werden. Das erste besteht darin, es aus dem Cross-Domain-Iframe zu entfernen, der in Zukunft vollständig von der Webplattform entfernt wird, obwohl dieser Plan anscheinend angehalten zu werden scheint.</p> <p> Welche Alternativen müssen wir in diesem Sinne <code>alert() , confirm() und prompt() ersetzen? Sie haben vielleicht von HTML gehört<dialog></dialog> Elemente, dieser Artikel wird sich darauf konzentrieren, wie man ihn in Verbindung mit JavaScript -Klassen verwendet.

    Obwohl es unmöglich ist, die volle Funktionalität des JavaScript -Dialogfelds vollständig zu kopieren, wenn wir<dialog></dialog> showModal() -Methode wird in Verbindung mit Versprechen verwendet (Versprechen kann auflösen (Akzeptieren) oder Abbrechen), sodass wir fast die gleiche Funktionalität erhalten können. Wenn wir noch einen Schritt weiter gehen, tun wir es für HTML<dialog></dialog> Elemente fügen Soundeffekte hinzu, genau wie ein echter Systemdialog!

    Wenn Sie die Demo jetzt anzeigen möchten, besuchen Sie hier.

    JavaScript Dialog

    Erstens benötigen wir eine grundlegende JavaScript -Klasse, die ein Einstellungsobjekt enthält, das mit den Standardeinstellungen zusammengeführt wird. Diese Einstellungen werden für alle Dialoge verwendet, es sei denn, Sie überschreiben sie, wenn Sie aufgerufen werden (dazu später mehr).

     Exportieren Sie Standardklassendialog {
      Konstruktor (Einstellungen = {}) {
        this.Settings = Object.assisign (
          {
            / * Standardeinstellungen - Siehe Beschreibung unten */
          },
          Einstellungen
        );
        this.init ();
      }
      // ...
    }

    Einstellungen umfassen:

    • accept : die Beschriftung der Schaltfläche "Akzeptieren".
    • bodyClass : Das Dialogfeld ist geöffnet und der Browser unterstützt es nicht<dialog></dialog> bei der CSS -Klasse des Elements hinzugefügt.
    • cancel : Die Beschriftung der Schaltfläche "Abbrechen".
    • dialogClass : Hinzufügen zu<dialog></dialog> Benutzerdefinierte CSS -Klasse für Elemente.
    • message :<dialog></dialog> Interner Inhalt.
    • soundAccept : Die URL der Audiodatei, die der Benutzer beim Klicken auf die Schaltfläche "Akzeptieren" abspielt.
    • soundOpen : Die URL der Audiodatei, die der Benutzer beim Öffnen des Dialogfelds abspielt.
    • template : Eine optionale HTML -Vorlage, injiziert in<dialog></dialog> Mitte.

    Initialisierungsvorlagen und Browserunterstützungserkennung

    In init -Methode werden wir eine Helferfunktion hinzufügen, um das HTML des Browsers zu erkennen<dialog></dialog> Unterstützung für Elemente und festlegen grundlegender HTML:

     init () {
      // Prüfen<dialog> Unterstützen Sie dies.
      this.dialog = document.createelement ('Dialog');
      this.dialog.dataset.comPonent = this.dialogSupported? 'Dialog': 'no-dialog';
      this.dialog.role = 'Dialog';
    
      // HTML -Vorlage this.dialog.innerhtml = `
        <fieldset data-ref="fieldset" role="document">
    <legend data-ref="message"></legend>
    <div data-ref="template"></div>
    </fieldset>
    <menu></menu> `;
    
      document.body.appendchild (this.dialog);
      // ...
    }</dialog>

    Browserpaar<dialog></dialog> Die Unterstützungssituation variiert, daher müssen wir Erkennung durchführen und eine Fallback -Lösung bereitstellen.

    (Die nachfolgenden Schritte ähneln dem Originaltext, und die Länge ist zu lang. Einige Codedetails werden hier weggelassen, aber wichtige Logik- und Code -Snippets bleiben beibehalten, und die Sprache wird poliert und angepasst.)

    ... (lassen Sie einige Codedetails aus, einschließlich DOM -Knoten -Referenzen, Schaltflächenattribute, Abbrechen -Schaltflächenereignisse, Polyfills, die Browser nicht unterstützen, Tastaturnavigation, Anzeige<dialog></dialog> Warten auf Benutzereingaben, Verstecken<dialog></dialog> , Fokusverarbeitung, Hinzufügen von alert , confirm und prompt Methoden, asynchron/Warten, Cross-Browser-Stile, benutzerdefinierte Dialogbeispiele usw.) ...

    Zusammenfassen

    Durch die in diesem Artikel bereitgestellten Lösungen können Sie problemlos modernere und flexiblere HTML verwenden<dialog></dialog> Elemente ersetzen herkömmliche JavaScript -Dialoge, um die Benutzererfahrung und die Anwendungsaufnahme zu verbessern. Denken Sie daran, den Stil und die Funktionalität nach Ihren spezifischen Anforderungen anzupassen, um ein benutzerdefiniertes Dialog zu erstellen, das Ihnen am besten passt.

Das obige ist der detaillierte Inhalt vonErsetzen Sie JavaScript -Dialoge durch das neue HTML -Dialogfeld. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme
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
Was ist CSS Grid?Was ist CSS Grid?Apr 30, 2025 pm 03:21 PM

CSS Grid ist ein leistungsstarkes Tool zum Erstellen komplexer, reaktionsschneller Weblayouts. Es vereinfacht das Design, verbessert die Zugänglichkeit und bietet mehr Kontrolle als ältere Methoden.

Was ist CSS Flexbox?Was ist CSS Flexbox?Apr 30, 2025 pm 03:20 PM

In Artikel wird CSS Flexbox erörtert, eine Layoutmethode zur effizienten Ausrichtung und Verteilung des Raums in reaktionsschnellen Designs. Es erklärt die Verwendung von Flexbox, vergleicht es mit CSS -Gitter und Details Browser -Unterstützung.

Wie können wir unsere Website mit CSS reagieren?Wie können wir unsere Website mit CSS reagieren?Apr 30, 2025 pm 03:19 PM

In dem Artikel werden Techniken zum Erstellen von reaktionsschnellen Websites mithilfe von CSS erörtert, einschließlich Ansichtsfenster -Meta -Tags, flexiblen Gitter, Flüssigkeitsmedien, Medienabfragen und relativen Einheiten. Es deckt auch mit CSS -Raster und Flexbox zusammen und empfiehlt CSS -Framework

Was macht die CSS-Box-Größeneigenschaft?Was macht die CSS-Box-Größeneigenschaft?Apr 30, 2025 pm 03:18 PM

In dem Artikel wird die CSS-Box-Größeneigenschaft erörtert, in der die Berechnung der Elementabmessungen steuert. Es erklärt Werte wie Inhaltsbox, Border-Box und Padding-Box sowie deren Auswirkungen auf das Layout-Design und die Form von Formularausrichtung.

Wie können wir mit CSS animieren?Wie können wir mit CSS animieren?Apr 30, 2025 pm 03:17 PM

In Artikel wird das Erstellen von Animationen mithilfe von CSS, Schlüsseleigenschaften und Kombination mit JavaScript erläutert. Hauptproblem ist die Browserkompatibilität.

Können wir mit CSS 3D -Transformationen zu unserem Projekt hinzufügen?Können wir mit CSS 3D -Transformationen zu unserem Projekt hinzufügen?Apr 30, 2025 pm 03:16 PM

In Artikel werden CSS für 3D -Transformationen, wichtige Eigenschaften, Browserkompatibilität und Leistungsüberlegungen für Webprojekte erläutert. (Charakterzahl: 159)

Wie können wir Gradienten in CSS hinzufügen?Wie können wir Gradienten in CSS hinzufügen?Apr 30, 2025 pm 03:15 PM

In dem Artikel werden CSS -Gradienten (linear, radial, wiederholt) beschrieben, um die Website -Visuals, das Hinzufügen von Tiefe, Fokus und moderne Ästhetik zu verbessern.

Was sind Pseudoelemente in CSS?Was sind Pseudoelemente in CSS?Apr 30, 2025 pm 03:14 PM

In Artikel werden Pseudoelemente in CSS, deren Verwendung bei der Verbesserung des HTML-Stylings und der Unterschiede zu Pseudoklassen erläutert. Bietet praktische Beispiele.

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

VSCode Windows 64-Bit-Download

VSCode Windows 64-Bit-Download

Ein kostenloser und leistungsstarker IDE-Editor von Microsoft

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

Dreamweaver Mac

Dreamweaver Mac

Visuelle Webentwicklungstools

SublimeText3 Linux neue Version

SublimeText3 Linux neue Version

SublimeText3 Linux neueste Version