Detaillierte Erklärung zur Verwendung des in Vue.js implementierten Kalender-Plugins

Detaillierte Erklärung zur Verwendung des in Vue.js implementierten Kalender-Plugins

Die heute zu implementierende Funktion ist die folgende Funktion: vue.js Simulationskalender-Plugin

Okay, Schluss mit dem Unsinn, kommen wir gleich zum Code

CSS:

*{
     Rand: 0;
     Polsterung: 0;
     -webkit-box-sizing: Rahmenbox;
     -moz-box-sizing: Rahmenbox;
     Box-Größe: Rahmenbox;
        }
        #app{
            Breite: 1000px;
            Rand: 10px automatisch;
        }
        .Kalander{
            Breite: 1000px;
        }
        .Kalendertabelle{
            Breite: 1000px;
        }
        .Kalendertabelle,th,tr,td{
            Rahmen: 1px durchgezogen #333333;
            Rahmen-Zusammenbruch: Zusammenbruch;
        }
        .Kalender td{
            Höhe: 100px;
            vertikale Ausrichtung: oben;
            Textausrichtung: links;
            Polsterung: 5px 0 0 5px;
            Schriftgröße: 13px;
        }
        .Kalender td.cur{
            Farbe: rot;
        }

html:

<div id="app">
    <div Klasse="Kalender">
        <Tabelle>
            <Beschriftung>
                <Wählen Sie v-Modell.Nummer="Jahr">
                    <option v-for="i von 490">{{i+1969}}</option>
                </Auswählen>
                <select v-model.number="Monat">
                    <option v-for="i von 12">{{i}}</option>
                </Auswählen>
            </caption>
            <Kopf>
            <tr>
                <th>Sonntag</th>
                <th>Montag</th>
                <th>Dienstag</th>
                <th>Mittwoch</th>
                <th>Donnerstag</th>
                <th>Freitag</th>
                <th>Samstag</th>
            </tr>
            </thead>
            <tbody>
            <!--index beginnt bei 0 und i beginnt bei 1-->
            <tr v-for="(a,index) von Kalenderlänge / 7" >
                <td v-for="i von 7" :class="{cur:calender[index * 7 + (i - 1)].cur }">{{calender[index * 7 + (i - 1)].fullDay}}</td>
            </tr>
            </tbody>
        </Tabelle>
    </div>
</div>

javascript - Argumente:

var vm = neuer Vue({
        el:'#app',
        Daten:{
            Jahr: 2018,
            Monat:1
        },
        berechnet:{
            Kalander(){
                var arr = [];

                //neue Daten haben drei Parameter: 1. Jahr 2. Monat 3. Der Standardwert ist 1. Wenn er 0 ist, bedeutet dies den letzten Tag des vorherigen Monats – die ersten zwei Tage 3. übermorgen var nowMonthLength = new Date(this.year,this.month,0).getDate();
                var nowMonthFirstWeek = neues Date(dieses.Jahr,dieser.Monat-1).getDay();
                var lastMonthLength = neues Datum (dieses Jahr, dieser Monat-1,0).getDate();
                console.log('Dieser Monat hat:' + nowMonthLength);
                console.log('Erster Tag dieses Monats' + nowMonthFirstWeek);
                console.log('Länge des letzten Monats' + letzteMonatslänge);

                // dieser.Monat = parseInt(dieser.Monat);
                //Welcher Monat ist der vorherige Monat jedes Monats? var pmonth = this.month == 1 ? 12 : this.month - 1;
                //Vorheriges Jahr var pyear = this.month == 1 ? this.year - 1 :this.year;
                //Nächster Monat var nmonth = this.month == 12 ? 1 : this.month + 1;
                //Nächster Monat var nyear = this.month == 12 ? this.year + 1 : this.year;
                //Funktion zum Auffüllen von Nullen // function toTwo(n) {
                // gebe n < 10 zurück? '0' + n : n;
                // }
                Funktion build(n) {
                    gibt n.toString().Länge > 1 zurück? n.toString() : '0' + n.toString();
                }
                // Die letzten Tage des letzten Monats hinzufügen while(nowMonthFirstWeek--){
                    arr.unshift({
                        Tag:letzteMonatslänge,
                        aktuell:wahr,
                        ganzerTag: `${pyear}-${buling(pmonth)}-${buling(lastMonthLength)}`
                    });
                    letzteMonatslänge--
                }
                Konsole.log(arr);

                //Tage dieses Monats var _a = 1;
                während(jetztMonatslänge--){
                    arr.push({
                        Tag:_a,
                        aktuell:false,
                        ganzerTag: `${dieses.Jahr}-${buling(dieser.Monat)}-${buling(_a)}`
                    });
                    _a++
                }

                //Nächsten Monat abschließen var nextLength = arr.length > 35 ? 42 - arr.length : 35 - arr.length;
                _a = 1;
                während (nächsteLänge--){
                    arr.push({
                        Tag:_a,
                        aktuell:wahr,
                        ganzerTag: `${nyear}-${buling(nmonth)}-${buling(_a)}`
                    });
                    _a++
                }
                Rückflug an;
            }
        }
    })

Hinweis: Sie müssen zuerst Ihre lokale vue.js-Datei importieren, bevor sie ordnungsgemäß ausgeführt werden kann!!!

Das Obige ist der vollständige Inhalt dieses Artikels. Ich hoffe, er wird für jedermanns Studium hilfreich sein. Ich hoffe auch, dass jeder 123WORDPRESS.COM unterstützen wird.

Das könnte Sie auch interessieren:
  • So verwenden Sie das Vue-Video-Player-Plugin für die Vue-Videowiedergabe
  • Eine einfache Möglichkeit, das Lodop-Plugin in Vue zu verwenden, um eine Druckfunktion zu implementieren
  • So verwenden Sie das Vue-Paging-Plugin
  • Detaillierte Erläuterung zur Verwendung des Vue WeChat-Sharing-Plugins
  • So verwenden Sie das Vue-Layer-Bullet-Box-Plugin im Vue-Projekt
  • Beispiel für die Verwendung des JSONP-Plugins in Vue
  • Detaillierte Erklärung zur Verwendung von vue-cropper, einem Vue-Plugin zum Zuschneiden von Bildern
  • Detaillierte Freigabe der Vue-Plugin-Nutzung

<<:  mysql 8.0.20 winx64.zip komprimierte Version Installations- und Konfigurationsmethode grafisches Tutorial

>>:  Eine vollständige Liste häufig verwendeter Linux-Befehle (empfohlene Sammlung)

Artikel empfehlen

CentOS7-Bereitstellung Flask (Apache, mod_wsgi, Python36, venv)

1. Installieren Sie Apache # yum install -y httpd...

CSS3 erstellt eine Webanimation, um einen springenden Balleffekt zu erzielen

Grundlegende Vorbereitung Für diese Implementieru...

Einführung und Verwendung des Javascript-Generators

Was ist ein Generator? Ein Generator ist ein Code...

Lösung für den Fehler „Mehrere Primärschlüssel definiert“ in MySQL

Es gibt zwei Möglichkeiten, einen Primärschlüssel...

Schritte zum Aktivieren von TLS in Docker für eine sichere Konfiguration

Vorwort Ich hatte zuvor die 2375 Remote API von D...

Workerman schreibt den Beispielcode des MySQL-Verbindungspools

Zunächst müssen Sie verstehen, warum Sie Verbindu...

HTML-Code für Multiheader-Tabellen

1. Code der Multiheader-Tabelle Code kopieren Der ...

vue.config.js Verpackungsoptimierungskonfiguration

Die Informationen auf Baidu sind so vielfältig, d...

Bringen Sie Ihnen bei, wie Sie eine Reaktion aus HTML implementieren

Was ist React React ist eine einfache JavaScript-...

jQuery implementiert dynamische Tag-Ereignisse

In diesem Artikel wird der spezifische Code von j...

Detaillierte Erklärung zur Verwendung von this.$set in Vue

Inhaltsverzeichnis Verwendung von this.$set in Vu...