Anmeldung + SessionStorageEffektanzeige
<Vorlage> <div Klasse="login-wrap"> <el-form class="login-container" ref="loginFormRef" :model="loginForm"> <h1 class="title">Benutzeranmeldung</h1> <el-form-item label=""> <el-input type="text" placeholder="Benutzerkonto" v-model="loginForm.username" autocomplete="off"></el-input> </el-form-item> <el-form-item label=""> <el-input type="text" placeholder="Benutzerpasswort" v-model="loginForm.password" autocomplete="off"></el-input> </el-form-item> <el-form-item> <el-radio-group v-model="loginForm.resource"> <el-radio label="Administrator"></el-radio> <el-radio label="Normaler Benutzer"></el-radio> </el-radio-gruppe> </el-form-item> <el-form-item> <template slot-scope="Umfang"> <el-button type="primary" @click="doLogin()" style="width: 100%;">Benutzeranmeldung</el-button> <!-- <el-button style="width: 48%;" @click="gotoRegister" >Benutzerregistrierung</el-button> --> </Vorlage> </el-form-item> <!-- <el-row style="text-align: center;"> <el-link @click="gotoRegister()">Benutzerregistrierung</el-link> <el-link>Passwort vergessen?</el-link> </el-row> --> </el-form> </div> </Vorlage> <Skript> Standard exportieren { Daten: Funktion() { zurückkehren { Anmeldeformular: { Benutzername: '', Passwort: '', Ressource: '' } } }, Methoden: { gotoRegister: Funktion() { dies.$router.push({ Name: "Registrieren" }); }, doLogin() { let Ressource = this.loginForm.resource dies.$refs.loginFormRef.validate(async valid => { wenn (!gültig) zurückgeben; if (Ressource == "Administrator") { Konstante { Daten:res } = warte auf this.axios.post("http://localhost:8088/loginadmin", this.loginForm) wenn (res) { this.$message.success("Administrator-Anmeldung erfolgreich") sessionStorage.setItem("personid","ljhjiayou") dies.$router.push({ Pfad: "/dong" }); } anders { this.$message.error("Konto- oder Passwortfehler") } //Normale Benutzeranmeldung }else{ Konstante { Daten:res } = warte auf this.axios.post("http://localhost:8088/loginuser", this.loginForm) wenn (res) { Konsole.log(res) this.$message.success("Normale Benutzeranmeldung erfolgreich") sessionStorage.setItem("Personen-ID",res) dies.$router.push({ Pfad: "/Person" }); } anders { this.$message.error("Konto- oder Passwortfehler") } } }) } } } </Skript> //scoped="scoped" bedeutet, dass der Stil nur die aktuelle VUE regelt <Stil scoped="Bereich"> .login-wrap { Box-Größe: Rahmenbox; Breite: 100 %; Höhe: 100%; Polsterung oben: 10%; background-image: url(); /* Hintergrundfarbe: #112346; */ Hintergrundwiederholung: keine Wiederholung; Hintergrundposition: Mitte rechts; Hintergrundgröße: 100 %; } .login-container { Rahmenradius: 10px; Rand: 0px automatisch; Breite: 350px; Polsterung: 30px 35px 15px 35px; Hintergrund: #fff; Rand: 1px durchgezogen #eaeaea; Textausrichtung: links; Kastenschatten: 0 0 20px 2px rgba (0, 0, 0, 0,1); } .Titel { Rand: 0px automatisch 40px automatisch; Textausrichtung: zentriert; Farbe: #505458; } </Stil> Paginierungstabelle Effektanzeige
<Vorlage> <div> <el-table :data="tableData" border style="width: 100%"> <el-table-column fixed prop="id" label="news id" width="150"> </el-Tabellenspalte> <el-table-column prop="typeid" label="Nachrichtentitel" width="200"> </el-Tabellenspalte> <el-table-column prop="otherid" label="Nachrichtenübersicht" width="200"> </el-table-column> <el-table-column prop="Geld" label="Nachrichteninhalt" width="200"> </el-Tabellenspalte> <el-table-column prop="datetime" label="Zeitpunkt der Pressemitteilung" width="150"> </el-table-column> <el-table-column fixed="rechts" label="Operation" width="200"> <template slot-scope="Umfang"> <el-button @click="updateExercise(scope.row)" size="mesdium" type="primary">Ändern</el-button> <el-button @click="deleteExercise(scope.row)" type="warning" size="medium">Löschen</el-button> </Vorlage> </el-Tabellenspalte> </el-Tabelle> <div Klasse="Block"> <el-pagination @size-change="Größenänderungshandle" @current-change="AktuelleÄnderungshandle" :current-page="aktuelleSeite" :page-sizes="[5, 10, 15, 20]" :page-size="Seitengröße" layout="Gesamt, Größen, Zurück, Pager, Weiter, Jumper" :total="Gesamtanzahl"> </el-pagination> </div> </div> </Vorlage> <Skript> Standard exportieren { Methoden: { handleSizeChange(Wert) { //Konsole.log(Wert) diese.Seitengröße = Wert; dies.loadData( diese.aktuelleSeite, diese.Seitengröße); }, handleCurrentChange(Wert) { console.log(Wert) diese.aktuelleSeite = Wert; dies.loadData( diese.aktuelleSeite, diese.Seitengröße); }, //Daten vom Server lesen loadData: function(pageNum, pageSize) { lass _this = dies; console.log(diese.Seitennummer) dies.axios.get("http://localhost:8088/records/querystudentbypage?pageNum=" + pageNum + "&Seitengröße=" + diese.Seitengröße).dann(Funktion(res) { //Konsole.log(res.data.pagestudentdata.list) _this.tableData = res.data.pagestudentdata.list; _this.totalCount = res.data.number; }, Funktion() { console.log('fehlgeschlagen'); }); }, }, Daten() { zurückkehren { // aktuelleSeite1: 5, // aktuelleSeite2: 5, // aktuelleSeite3: 5, // aktuelleSeite4: 4, aktuelleSeite: 1, Tabellendaten: null, Seitengröße: 5, Gesamtanzahl: 15, Seitennummer: 1, }; }, erstellt() { // lass _this = dies; // axios.get("http://localhost:8088/records").then(Funktion(Antwort) { // _this.tableData = antwort.data // }) dies.loadData(diese.Seitennummer, diese.Seitengröße) }, } </Skript>
@AntwortBody @RequestMapping(Wert = "/querystudentbypage", Methode = RequestMethod.GET) öffentliche Map<String, Object> querystudentbypage(@RequestParam(value="Seitennummer")int Seitennummer, @RequestParam(value="Seitengröße")int Seitengröße) { PageHelper.startPage(Seitennummer,Seitengröße); Liste<Datensätze> Kurse = RecordsMapper.selectList(null); PageInfo<Datensätze> Seite = neue PageInfo<>(Kurse); System.out.println("---------------"+Seite); Map<String, Objekt> map = neue HashMap<String, Objekt>(); map.put("pagestudentdata", Seite); map.put("Zahl", page.getTotal()); Rückfahrkarte; } Referenzlinks Schalter + TabEffektanzeige
Hauptcode des Frontend-Switchs <el-table-column prop="name" label="Ob eingefroren werden soll" width="150"> <template slot-scope="Umfang"> <el-switch v-model="scope.row.statusid" :aktiver-Wert="1" :inaktiver-Wert="2" @change="switchChange($event, scope.row)" aktiv-color="#13ce66" inaktive Farbe="#ff4949"></el-switch> </Vorlage> </el-Tabellenspalte> Vollständiger Code <Vorlage> <el-tabs v-model="aktiverName" @tab-click="handleClick"> <el-tab-pane label="Alle Konten" name="first"> <el-table :data="tableData" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Konto-ID" width="150"> </el-Tabellenspalte> <el-table-column prop="password" label="Passwort" width="200"> </el-Tabellenspalte> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column prop="name" label="Ob eingefroren werden soll" width="150"> <template slot-scope="Umfang"> <el-switch v-model="scope.row.statusid" :aktiver-Wert="1" :inaktiver-Wert="2" @change="switchChange($event, scope.row)" aktiv-color="#13ce66" inaktive Farbe="#ff4949"></el-switch> </Vorlage> </el-Tabellenspalte> <el-table-column prop="Personen-ID" label="Personen-ID" width="200"> </el-Tabellenspalte> <el-table-column fixed="rechts" label="Operation" width="200"> <template slot-scope="Umfang"> <el-button @click="Übung löschen(scope.row)" Typ="Warnung" Größe="mittel" >Löschen</el-Button > </Vorlage> </el-Tabellenspalte> </el-Tabelle> </el-tab-pane> <el-tab-pane label="Eingefrorenes Konto" name="second"> <el-table :data="tableDatab" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Konto-ID" width="150"> </el-Tabellenspalte> <el-table-column prop="personinfo.realname" label="name" width="200"> </el-Tabellenspalte> <el-table-column prop="password" label="Passwort" width="200"> </el-Tabellenspalte> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column fixed="rechts" label="Operation" width="200"> <template slot-scope="Umfang"> <el-button @click="qiyong(scope.row)" Typ="Warnung" Größe="mittel" >Aktivieren</el-button > </Vorlage> </el-Tabellenspalte> </el-Tabelle> </el-tab-pane> <el-tab-pane label="Aktivierte Konten" name="third"> <el-table :data="tableDatabc" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Konto-ID" width="150"> </el-Tabellenspalte> <el-table-column prop="personinfo.realname" label="name" width="200"> </el-Tabellenspalte> <el-table-column prop="password" label="Passwort" width="200"> </el-Tabellenspalte> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column fixed="rechts" label="Operation" width="200"> <template slot-scope="Umfang"> <el-button @click="dongjie(scope.row)" Typ="Warnung" Größe="mittel" >Einfrieren</el-Schaltfläche > </Vorlage> </el-Tabellenspalte> </el-Tabelle> </el-tab-pane> </el-tabs> </Vorlage> <Skript> Standard exportieren { Daten() { zurückkehren { Tabellendaten: null, tableDatab: null, tableDatabc: null, aktiverName: "Vorname" }; }, Methoden: { handleClick(tab, Ereignis) { console.log(Tab, Ereignis); }, switchChange(e, Daten) { wenn (e == 1) { axios.get('http://localhost:8088/accounts/kaiqi/' + data.accoundid).then((res) => { diese.$nachricht({ Meldung: "Erfolgreich geöffnet", Typ: „Erfolg“ }); // Standort.neu laden() }); } sonst wenn (e == 2) { axios.get('http://localhost:8088/accounts/dongjie/' + data.accoundid).then((res) => { diese.$nachricht({ Meldung: "Einfrieren erfolgreich", Typ: „Erfolg“ }); // Standort.neu laden() }); } }, dongjie(Zeile) { lass _dies=dies this.$confirm('Sind Sie sicher, dass Sie das Konto von '+row.personinfo.realname+' einfrieren möchten?', 'Konto einfrieren', { confirmButtonText: 'Bestätigen', cancelButtonText: 'Abbrechen', Typ: "Warnung" }).dann(()=>{ axios.get('http://localhost:8088/accounts/dongjie/'+row.accoundid).then(Funktion (Antwort){ wenn (Antwort.Daten) { _this.$alert(row.personinfo.realname+'Konto erfolgreich eingefroren!', 'Konto einfrieren',{ confirmButtonText: 'Bestätigen', Rückruf: Aktion =>{ Standort.neu laden() } }); } }) }).fangen(()=>{ }); }, qiyong(Reihe) { lass _dies=dies this.$confirm('Möchten Sie das Konto wirklich mit '+row.personinfo.realname+' aktivieren?', 'Konto aktivieren', { confirmButtonText: 'Bestätigen', cancelButtonText: 'Abbrechen', Typ: "Warnung" }).dann(()=>{ axios.get('http://localhost:8088/accounts/kaiqi/'+row.accoundid).then(Funktion (Antwort){ wenn (Antwort.Daten) { _this.$alert(row.personinfo.realname+'Das Konto wurde erfolgreich aktiviert!', 'Konto aktivieren',{ confirmButtonText: 'Bestätigen', Rückruf: Aktion =>{ Standort.neu laden() } }); } }) }).fangen(()=>{ }); }, löscheÜbung(Zeile) { lass _dies=dies this.$confirm('Möchten Sie das Konto '+row.accoundid+' wirklich löschen?','Konto löschen',{ confirmButtonText: 'Bestätigen', cancelButtonText: 'Abbrechen', Typ: "Warnung" }).dann(()=>{ axios.delete('http://localhost:8088/accounts/'+row.accoundid).then(Funktion (Antwort){ wenn (Antwort.Daten) { _this.$alert(row.accoundid+'Konto erfolgreich gelöscht!', 'Konto löschen',{ confirmButtonText: 'Bestätigen', Rückruf: Aktion =>{ Standort.neu laden() } }); } }) }).fangen(()=>{ }); }, }, erstellt(){ lass _dies=dies; axios.get("http://localhost:8088/accounts").then(Funktion (Antwort){ _this.tableData=Antwort.data }) axios.get("http://localhost:8088/accounts/dongjie").then(Funktion (Antwort){ _this.tableDatab=Antwort.Daten }) axios.get("http://localhost:8088/accounts/qiyong").then(Funktion (Antwort){ _this.tableDatabc=Antwort.Daten }) }, }; </Skript> Frontend-Abfangjäger
Haupt-JS router.beforeEach((bis, von, weiter) => { // nächste() if (to.meta.requireAuth) { // Bestimmen Sie, ob die Route eine Anmeldeberechtigung erfordert if (sessionStorage.getItem("personid")) { nächste() } anders { // Nicht angemeldet, springe zur Anmeldeseite next('/') } } anders { nächste() } }) route.js
{ Pfad: '/listxw', Name: 'News Management', Komponente: Index, zeigen: wahr, Meta: { requireAuth: wahr }, Weiterleitung: "/listxw", Kinder: [{ Pfad: "/addxw", Name: "Neuigkeiten hinzufügen", Komponente: addxw, Meta: { requireAuth: wahr }, }, { Pfad: "/updatexw", Name: "Nachrichten ändern", Komponente: updatexw, Meta: { requireAuth: wahr }, }, { Pfad: '/listxw', Name: 'Nachrichtenliste', Komponente: listxw, Meta: { requireAuth: wahr }, }, { Pfad: '/Person', Name: „Persönliche Daten“, Komponente: Person, Meta: { requireAuth: wahr }, }, { Pfad: '/record', Name: 'Transaktionsdatensatz', Komponente: Datensatz, Meta: { requireAuth: wahr }, } ], }, Rich-Text-Editor Effektanzeige
Vollständiger Code <Vorlage> <div> <el-form ref="loginFormRef" label-width="100px" style="width: 60%" :model="loginForm"> <el-form-item label="Nachrichtentitel"> <el-input v-model="loginForm.title"></el-input> </el-form-item> <el-form-item label="Nachrichtenübersicht"> <el-input v-model="loginForm.newsabstract"></el-input> </el-form-item> <el-form-item label="Neuigkeiteninhalt"> <div Klasse="Bearbeiten_Container" Stil="Breite: 100%"> <quill-editor v-model="loginForm.text" ref="myQuillEditor" :options="editorOption" @blur="beimEditorBlur($event)" @focus="beimEditorFocus($event)" @change="beimEditorÄndern($event)"> </Feder-Editor> </div> </el-form-item> <el-form-item> <el-button type="primary" @click="changePwd()">Neuigkeiten hinzufügen</el-button> </el-form-item> </el-form> <div v-html="str" class="ql-editor"> {{str}} </div> </div> </Vorlage> <Skript> importieren { Federeditor } von „vue-quill-editor“; //Editor aufrufen import 'quill/dist/quill.core.css'; importiere „quill/dist/quill.snow.css“; importiere „quill/dist/quill.bubble.css“; Standard exportieren { Komponenten: Federeditor }, Daten() { zurückkehren { Anmeldeformular: { Titel: "", newsabstract: "", text: "", Veröffentlichungsdatum: "", }, str: '', }; }, Methoden: { changePwd: Funktion() { dies.$refs.loginFormRef.validate(async valid => { wenn (!gültig) zurückgeben; Konstante { Daten:res } = warte auf this.axios.put("http://localhost:8088/news", this.loginForm) wenn (res) { this.$message.success("Neuigkeiten erfolgreich hinzugefügt") dies.$router.push({ Pfad: "/listxw" }); } anders { this.$message.error("Neuigkeiten konnten nicht hinzugefügt werden") } }) }, onEditorReady(editor) { // Editor vorbereiten }, onEditorBlur() {}, // Fokusverlust-Ereignis onEditorFocus() {}, // Fokusgewinn-Ereignis onEditorChange() {}, // Inhaltsänderungsereignis // Transkodierung escapeStringHTML(str) { str = str.replace(/</g, '<'); str = str.replace(/>/g, '>'); gibt str zurück; } }, berechnet: { Herausgeber() { gib dies zurück.$refs.myQuillEditor.quill; }, }, montiert() { let content = '<ul><li><strong>Anforderungszeichenfolge</strong></li><li><strong><u>Anforderungszeichenfolge</u></strong></li><li><strong><s><u>Anforderungszeichenfolge</u></s></strong></li><li><em>Anforderungszeichenfolge</em></li></ul>'; // Fordern Sie die vom Hintergrund zurückgegebene Inhaltszeichenfolge an this.str = this.escapeStringHTML(content); } }; </Skript> <Stil> </Stil> Referenzlink zur Verwendung des Rich-Text-Editors in Vue
Dies ist das Ende dieses Artikels über die detaillierte Verwendung von ElementUI in Vue. Weitere relevante Inhalte zur Verwendung von Vue ElementUI finden Sie in früheren Artikeln auf 123WORDPRESS.COM oder in den folgenden verwandten Artikeln. Ich hoffe, dass jeder 123WORDPRESS.COM in Zukunft unterstützen wird! Das könnte Sie auch interessieren:
|
<<: Analyse der MySQL-Transaktionsmerkmale und Ebenenprinzipien
>>: Kommentare auf Webseiten verursachen Textüberlauf im Internet Explorer
Detaillierte Erklärung von HTML (Option auswählen)...
Ich habe zuvor die Verwendung des asynchronen Lad...
MySQL ist eine kostenlose relationale Datenbank m...
Die Portzuordnung ist nicht die einzige Möglichke...
Ich habe heute Redis installiert und es sind eini...
Inhaltsverzeichnis Vorwort Tatsächlicher Kampf 1....
MySQL-Tuning: Detaillierte Erläuterung und prakti...
Inhaltsverzeichnis Verwenden bedingter Typen in g...
Inhaltsverzeichnis Vorherige Wörter Synchron und ...
In diesem Artikel wird beschrieben, wie Sie eine ...
Inhaltsverzeichnis Routenplaner Hintergrund Erste...
Es gibt viele XHTML-Tags: div, ul, li, dl, dt, dd...
Ich habe „Patterns for Sign Up & Ramp Up“ vor ...
Der Dateiserver ist einer der am häufigsten verwe...
1. Sehen Sie sich die Feldtypen in der Tabelle an...