Heim > Web-Frontend > Front-End-Fragen und Antworten > jquery kann kein Datum dynamisch hinzufügen

jquery kann kein Datum dynamisch hinzufügen

PHPz
Freigeben: 2023-05-11 17:41:07
Original
517 Leute haben es durchsucht

In den letzten Jahren hat sich jQuery mit der kontinuierlichen Weiterentwicklung der Front-End-Technologie zu einer der am häufigsten verwendeten JavaScript-Bibliotheken in der Webentwicklung entwickelt. Es bietet eine Vielzahl einfacher und benutzerfreundlicher Schnittstellen und Funktionen, was die JavaScript-Codierungsarbeit erheblich vereinfacht. Bei der praktischen Anwendung werden wir jedoch zwangsläufig auf einige Schwierigkeiten stoßen. Dieser Artikel konzentriert sich auf ein Thema: wie man dynamisch eine Datumsauswahl hinzufügt.

Die Datumsauswahl ist eines der am häufigsten verwendeten Steuerelemente in Webformularen. In jQuery stehen uns auch verschiedene Selektor-Plug-Ins zur Verfügung. Es gibt jedoch immer noch Situationen, in denen wir eine Datumsauswahl dynamisch hinzufügen müssen, und in diesem Fall müssen wir den Code selbst schreiben.

Angenommen, wir müssen der Seite ein Datumsauswahlsteuerelement hinzufügen. Das Folgende ist ein einfacher Beispielcode:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>动态添加日期选择控件示例</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <link rel="stylesheet" type="text/css" href="https://cdn.bootcdn.net/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css">
    <script src="https://cdn.bootcdn.net/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
</head>
<body>
    <h1>动态添加日期选择控件示例</h1>
    <div id="datepicker"></div>
    <button id="addDatepicker">添加日期选择控件</button>
    <script>
        $(document).ready(function() {
            $('#addDatepicker').click(function() {
                $('#datepicker').datepicker();
            });
        });
    </script>
</body>
</html>
Nach dem Login kopieren

Im obigen Code haben wir zunächst die zugehörigen Dateien von jQuery und der jQuery-Benutzeroberfläche vorgestellt. Dann haben wir der Seite ein div-Element hinzugefügt und seine ID auf „datepicker“ gesetzt. Als nächstes wird unterhalb des div-Elements ein Button-Element hinzugefügt und seine ID auf „addDatepicker“ gesetzt.

Im letzten Skript-Tag verwenden wir die .ready()-Methode von jQuery, um festzustellen, ob das Seiten-DOM bereit ist, und fügen dann der Schaltfläche ein Klickereignis hinzu. In diesem Ereignishandler rufen wir die von der jQuery-Benutzeroberfläche bereitgestellte datepicker()-Methode auf, um dem Div-Element eine Datumsauswahl hinzuzufügen.

Es scheint, dass es kein Problem mit dem Code geben sollte. Warum erscheint die Datumsauswahl nicht? Wir haben festgestellt, dass der obige Code zwar die Schaltfläche beim Rendern der Seite rendern kann, die Datumsauswahl jedoch nach dem Klicken nicht angezeigt wird.

Nach der Analyse haben wir festgestellt, dass das Problem in der Funktion der Schaltfläche „Ereignis hinzufügen“ liegt. Genauer gesagt liegt das Problem bei der Methode datepicker(). Der Grund für dieses Problem liegt darin, dass die .load()-Methode von jQuery veraltet ist und die datepicker()-Methode von der .load()-Methode abhängt. Mit anderen Worten: Da die Methode .load() nicht mehr unterstützt wird, kann die Methode datepicker() nicht ordnungsgemäß funktionieren.

Um dieses Problem zu lösen, können wir eine modernere Methode verwenden, um dynamisch eine Datumsauswahl hinzuzufügen. Konkret können wir die .on()-Methode von jQuery verwenden, um das Ereignis wie folgt zu binden:

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>动态添加日期选择控件示例</title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
    <link rel="stylesheet" type="text/css" href="https://cdn.bootcdn.net/ajax/libs/jqueryui/1.12.1/jquery-ui.min.css">
    <script src="https://cdn.bootcdn.net/ajax/libs/jqueryui/1.12.1/jquery-ui.min.js"></script>
</head>
<body>
    <h1>动态添加日期选择控件示例</h1>
    <div id="datepicker"></div>
    <button id="addDatepicker">添加日期选择控件</button>
    <script>
        $(document).ready(function() {
            $('#addDatepicker').on('click', function() {
                $('<input>').appendTo('#datepicker').datepicker();
            });
        });
    </script>
</body>
</html>
Nach dem Login kopieren

Wir müssen dem Datumsauswahl-Steuerelement ein Eingabefeld hinzufügen und dann die datepicker()-Methode aufrufen. Diese Methode funktioniert einwandfrei und fügt die Datumsauswahl dynamisch hinzu.

In praktischen Anwendungen stoßen wir häufig auf verschiedene Probleme wie Positionskonflikte und Formatfehler. Im Allgemeinen müssen wir bei der Verwendung der Datumsauswahl von jQuery auf die folgenden Punkte achten:

  1. Führen Sie die erforderlichen Dateien entsprechend ein. Die relevanten Dateien von JQuery und der jQuery-Benutzeroberfläche müssen eingeführt werden.
  2. Verwenden Sie die neueste Ereignisbindungsmethode. Die alte Methode ist veraltet.
  3. Befolgen Sie die Beispiele auf der API und verwenden Sie die relevanten Methoden korrekt.
  4. Achten Sie auf das Datumsformat. Verschiedene Länder und Regionen haben unterschiedliche Zeitformate, daher müssen Sie darauf achten.

Kurz gesagt, das dynamische Hinzufügen einer Datumsauswahl scheint einfach zu sein, bringt aber tatsächlich viele Probleme mit sich. Nur wenn wir die API-Dokumentation sorgfältig lesen, den Code standardisieren und auf das Zeitformat und andere Probleme achten, kann unser Code normal ausgeführt werden.

Das obige ist der detaillierte Inhalt vonjquery kann kein Datum dynamisch hinzufügen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage