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
In diesem Artikelbeispiel wird der spezifische Co...
Es gibt zwei Möglichkeiten, nodejs unter Linux zu...
Vorne geschrieben Nginx ist nicht nur ein Reverse...
Inhaltsverzeichnis Vorwort 1. Ursache des Problem...
Die Verwendung von Vue + ElementUI Tree dient zu ...
Seit der Aktivierung des https-Zugriffs für die g...
IE8 wird mehrere Kompatibilitätsmodi haben. Der IE...
1. Wie MySQL Indizes verwendet Indizes werden ver...
In diesem Artikel wird eine kleine Demo gezeigt, ...
Schauen wir uns zunächst meinen Fehlercode an. ht...
Inhaltsverzeichnis Was ist Docker einsetzen 1. Zi...
Vorwort Ich habe vor Kurzem MySQL 5.7 installiert...
Google China hat ein Übersetzungstool veröffentlic...
Inhaltsverzeichnis Ausgabe Ausgabepfad Ausgabe.öf...
1. DOCTYPE ist unverzichtbar. Der Browser bestimm...