Login + sessionStorageEffect display
<template> <div class="login-wrap"> <el-form class="login-container" ref="loginFormRef" :model="loginForm"> <h1 class="title">User login</h1> <el-form-item label=""> <el-input type="text" placeholder="User account" v-model="loginForm.username" autocomplete="off"></el-input> </el-form-item> <el-form-item label=""> <el-input type="text" placeholder="User password" 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="Ordinary user"></el-radio> </el-radio-group> </el-form-item> <el-form-item> <template slot-scope="scope"> <el-button type="primary" @click="doLogin()" style="width: 100%;">User login</el-button> <!-- <el-button style="width: 48%;" @click="gotoRegister" >User registration</el-button> --> </template> </el-form-item> <!-- <el-row style="text-align: center;"> <el-link @click="gotoRegister()">User registration</el-link> <el-link>Forgot your password?</el-link> </el-row> --> </el-form> </div> </template> <script> export default { data: function() { return { loginForm: { username: '', password: '', resource: '' } } }, methods: { gotoRegister: function() { this.$router.push({ name: 'register' }); }, doLogin() { let resource = this.loginForm.resource this.$refs.loginFormRef.validate(async valid => { if (!valid) return; if (resource == "Administrator") { const { data:res } = await this.axios.post("http://localhost:8088/loginadmin", this.loginForm) if (res) { this.$message.success("Administrator login successful") sessionStorage.setItem("personid","ljhjiayou") this.$router.push({ path: "/dong" }); } else { this.$message.error("Account or password error") } //Ordinary user login }else{ const { data:res } = await this.axios.post("http://localhost:8088/loginuser", this.loginForm) if (res) { console.log(res) this.$message.success("Ordinary user login successful") sessionStorage.setItem("personid",res) this.$router.push({ path: "/person" }); } else { this.$message.error("Account or password error") } } }) } } } </script> //scoped="scoped" means the style only regulates the current VUE <style scoped="scoped"> .login-wrap { box-sizing: border-box; width: 100%; height: 100%; padding-top: 10%; background-image: url(); /* background-color: #112346; */ background-repeat: no-repeat; background-position: center right; background-size: 100%; } .login-container { border-radius: 10px; margin: 0px auto; width: 350px; padding: 30px 35px 15px 35px; background: #fff; border: 1px solid #eaeaea; text-align: left; box-shadow: 0 0 20px 2px rgba(0, 0, 0, 0.1); } .title { margin: 0px auto 40px auto; text-align: center; color: #505458; } </style> Pagination table Effect display
<template> <div> <el-table :data="tableData" border style="width: 100%"> <el-table-column fixed prop="id" label="news id" width="150"> </el-table-column> <el-table-column prop="typeid" label="News title" width="200"> </el-table-column> <el-table-column prop="otherid" label="News Summary" width="200"> </el-table-column> <el-table-column prop="money" label="News content" width="200"> </el-table-column> <el-table-column prop="datetime" label="News release time" width="150"> </el-table-column> <el-table-column fixed="right" label="Operation" width="200"> <template slot-scope="scope"> <el-button @click="updateExercise(scope.row)" size="mesdium" type="primary">Modify</el-button> <el-button @click="deleteExercise(scope.row)" type="warning" size="medium">Delete</el-button> </template> </el-table-column> </el-table> <div class="block"> <el-pagination @size-change="handleSizeChange" @current-change="handleCurrentChange" :current-page="currentPage" :page-sizes="[5, 10, 15, 20]" :page-size="pageSize" layout="total, sizes, prev, pager, next, jumper" :total="totalCount"> </el-pagination> </div> </div> </template> <script> export default { methods: { handleSizeChange(val) { //console.log(val) this.pageSize = val; this.loadData( this.currentPage, this.pageSize); }, handleCurrentChange(val) { console.log(val) this.currentPage = val; this.loadData( this.currentPage, this.pageSize); }, //Read data from the server loadData: function(pageNum, pageSize) { let _this = this; console.log(this.pageNum) this.axios.get("http://localhost:8088/records/querystudentbypage?pageNum=" + pageNum + "&pageSize=" + this.pageSize).then(function(res) { //console.log(res.data.pagestudentdata.list) _this.tableData = res.data.pagestudentdata.list; _this.totalCount = res.data.number; }, function() { console.log('failed'); }); }, }, data() { return { // currentPage1: 5, // currentPage2: 5, // currentPage3: 5, // currentPage4: 4, currentPage: 1, tableData: null, pageSize: 5, totalCount: 15, pageNum: 1, }; }, created() { // let _this = this; // axios.get("http://localhost:8088/records").then(function(response) { // _this.tableData = response.data // }) this.loadData(this.pageNum, this.pageSize) }, } </script>
@ResponseBody @RequestMapping(value = "/querystudentbypage", method = RequestMethod.GET) public Map<String, Object> querystudentbypage(@RequestParam(value="pageNum")int pageNum, @RequestParam(value="pageSize")int pageSize) { PageHelper.startPage(pageNum,pageSize); List<Records> courses = recordsMapper.selectList(null); PageInfo<Records> page = new PageInfo<>(courses); System.out.println("---------------"+page); Map<String, Object> map = new HashMap<String, Object>(); map.put("pagestudentdata", page); map.put("number", page.getTotal()); return map; } Reference Links Switch + TabEffect display
Front-end switch main code <el-table-column prop="name" label="Whether to freeze" width="150"> <template slot-scope="scope"> <el-switch v-model="scope.row.statusid" :active-value="1" :inactive-value="2" @change="switchChange($event, scope.row)" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </template> </el-table-column> Complete code <template> <el-tabs v-model="activeName" @tab-click="handleClick"> <el-tab-pane label="All Accounts" name="first"> <el-table :data="tableData" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Account id" width="150"> </el-table-column> <el-table-column prop="password" label="Password" width="200"> </el-table-column> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column prop="name" label="Whether to freeze" width="150"> <template slot-scope="scope"> <el-switch v-model="scope.row.statusid" :active-value="1" :inactive-value="2" @change="switchChange($event, scope.row)" active-color="#13ce66" inactive-color="#ff4949"></el-switch> </template> </el-table-column> <el-table-column prop="personid" label="personid" width="200"> </el-table-column> <el-table-column fixed="right" label="Operation" width="200"> <template slot-scope="scope"> <el-button @click="deleteExercise(scope.row)" type="warning" size="medium" >Delete</el-button > </template> </el-table-column> </el-table> </el-tab-pane> <el-tab-pane label="Frozen Account" name="second"> <el-table :data="tableDatab" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Account id" width="150"> </el-table-column> <el-table-column prop="personinfo.realname" label="name" width="200"> </el-table-column> <el-table-column prop="password" label="Password" width="200"> </el-table-column> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column fixed="right" label="Operation" width="200"> <template slot-scope="scope"> <el-button @click="qiyong(scope.row)" type="warning" size="medium" >Enable</el-button > </template> </el-table-column> </el-table> </el-tab-pane> <el-tab-pane label="Enabled Accounts" name="third"> <el-table :data="tableDatabc" border style="width: 100%"> <el-table-column fixed prop="accoundid" label="Account id" width="150"> </el-table-column> <el-table-column prop="personinfo.realname" label="name" width="200"> </el-table-column> <el-table-column prop="password" label="Password" width="200"> </el-table-column> <el-table-column prop="balance" label="Balance" width="200"> </el-table-column> <el-table-column fixed="right" label="Operation" width="200"> <template slot-scope="scope"> <el-button @click="dongjie(scope.row)" type="warning" size="medium" >Freeze</el-button > </template> </el-table-column> </el-table> </el-tab-pane> </el-tabs> </template> <script> export default { data() { return { tableData: null, tableDatab: null, tableDatabc: null, activeName: 'first' }; }, methods: { handleClick(tab, event) { console.log(tab, event); }, switchChange(e, data) { if (e == 1) { axios.get('http://localhost:8088/accounts/kaiqi/' + data.accoundid).then((res) => { this.$message({ message: "Open successfully", type: "success" }); // location.reload() }); } else if (e == 2) { axios.get('http://localhost:8088/accounts/dongjie/' + data.accoundid).then((res) => { this.$message({ message: "Freeze successful", type: "success" }); // location.reload() }); } }, dongjie(row) { let _this=this this.$confirm('Are you sure you want to freeze the account of '+row.personinfo.realname+'?', 'Freeze account', { confirmButtonText: 'Confirm', cancelButtonText: 'Cancel', type: 'warning' }).then(()=>{ axios.get('http://localhost:8088/accounts/dongjie/'+row.accoundid).then(function (response){ if (response.data) { _this.$alert(row.personinfo.realname+'Account frozen successfully!', 'Freeze account',{ confirmButtonText: 'Confirm', callback: action =>{ location.reload() } }); } }) }).catch(()=>{ }); }, qiyong(row) { let _this=this this.$confirm('Are you sure you want to enable the account with '+row.personinfo.realname+'?', 'Enable account', { confirmButtonText: 'Confirm', cancelButtonText: 'Cancel', type: 'warning' }).then(()=>{ axios.get('http://localhost:8088/accounts/kaiqi/'+row.accoundid).then(function (response){ if (response.data) { _this.$alert(row.personinfo.realname+'The account is enabled successfully!', 'Enable account',{ confirmButtonText: 'Confirm', callback: action =>{ location.reload() } }); } }) }).catch(()=>{ }); }, deleteExercise(row) { let _this=this this.$confirm('Are you sure you want to delete the account'+row.accoundid+'?','Delete account',{ confirmButtonText: 'Confirm', cancelButtonText: 'Cancel', type: 'warning' }).then(()=>{ axios.delete('http://localhost:8088/accounts/'+row.accoundid).then(function (response){ if (response.data) { _this.$alert(row.accoundid+'Account deleted successfully!', 'Delete account',{ confirmButtonText: 'Confirm', callback: action =>{ location.reload() } }); } }) }).catch(()=>{ }); }, }, created(){ let _this=this; axios.get("http://localhost:8088/accounts").then(function (response){ _this.tableData=response.data }) axios.get("http://localhost:8088/accounts/dongjie").then(function (response){ _this.tableDatab=response.data }) axios.get("http://localhost:8088/accounts/qiyong").then(function (response){ _this.tableDatabc=response.data }) }, }; </script> Front-end interceptor
main.js router.beforeEach((to, from, next) => { // next() if (to.meta.requireAuth) { // Determine whether the route requires login permission if (sessionStorage.getItem("personid")) { next() } else { // Not logged in, jump to the login page next('/') } } else { next() } }) route.js
{ path: '/listxw', name: 'News Management', component: Index, show: true, meta: { requireAuth: true }, redirect: "/listxw", children: [{ path: "/addxw", name: "Add News", component: addxw, meta: { requireAuth: true }, }, { path: "/updatexw", name: "Modify News", component: updatexw, meta: { requireAuth: true }, }, { path: '/listxw', name: 'News List', component: listxw, meta: { requireAuth: true }, }, { path: '/person', name: 'Personal Information', component: person, meta: { requireAuth: true }, }, { path: '/record', name: 'Transaction Record', component: record, meta: { requireAuth: true }, } ], }, Rich text editor Effect display
Complete code <template> <div> <el-form ref="loginFormRef" label-width="100px" style="width: 60%" :model="loginForm"> <el-form-item label="News title"> <el-input v-model="loginForm.title"></el-input> </el-form-item> <el-form-item label="News Summary"> <el-input v-model="loginForm.newsabstract"></el-input> </el-form-item> <el-form-item label="News content"> <div class="edit_container" style="width: 100%"> <quill-editor v-model="loginForm.text" ref="myQuillEditor" :options="editorOption" @blur="onEditorBlur($event)" @focus="onEditorFocus($event)" @change="onEditorChange($event)"> </quill-editor> </div> </el-form-item> <el-form-item> <el-button type="primary" @click="changePwd()">Add news</el-button> </el-form-item> </el-form> <div v-html="str" class="ql-editor"> {{str}} </div> </div> </template> <script> import { quillEditor } from "vue-quill-editor"; //Call editor import 'quill/dist/quill.core.css'; import 'quill/dist/quill.snow.css'; import 'quill/dist/quill.bubble.css'; export default { components: quillEditor }, data() { return { loginForm: { title: "", newsabstract: "", text: "", releasedate: "", }, str: '', }; }, methods: { changePwd: function() { this.$refs.loginFormRef.validate(async valid => { if (!valid) return; const { data:res } = await this.axios.put("http://localhost:8088/news", this.loginForm) if (res) { this.$message.success("News added successfully") this.$router.push({ path: "/listxw" }); } else { this.$message.error("Failed to add news") } }) }, onEditorReady(editor) { // Prepare editor }, onEditorBlur() {}, // Loss of focus event onEditorFocus() {}, // Gain of focus event onEditorChange() {}, // Content change event // Transcoding escapeStringHTML(str) { str = str.replace(/</g, '<'); str = str.replace(/>/g, '>'); return str; } }, computed: { editor() { return this.$refs.myQuillEditor.quill; }, }, mounted() { let content = '<ul><li><strong>李佳豪</strong></li><li><strong><u>陈刚</u></strong></li><li><strong><s><u>李锦鸣</u></s></strong></li><li><em>杨军</em></li></ul>'; // Request the content string returned by the background this.str = this.escapeStringHTML(content); } }; </script> <style> </style> Reference link for using rich text editor in vue
This is the end of this article about the detailed usage of ElementUI in vue. For more relevant vue ElementUI usage content, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope everyone will support 123WORDPRESS.COM in the future! You may also be interested in:
|
<<: Analysis of Mysql transaction characteristics and level principles
>>: Web page comments cause text overflow in IE
background During the project development process...
Adobe Brackets is an open source, simple and powe...
Table of contents Introduction Description Naming...
1. Spread Operator The spread operator is three d...
Table of contents Docker container data volume Us...
We need to first combine the air quality data wit...
emmm the name is just a random guess 2333 Preface...
Preface ActiveMQ is the most popular and powerful...
This article example shares the specific code of ...
Table of contents 1. Understanding the stack stru...
1. Download the virtual machine version 15.5.1 I ...
Table of contents I. Overview 2. Conventional mul...
Table of contents 1. Background of WAF 2. What is...
During the configuration of Jenkins+Tomcat server...
Introduction to CentOS CentOS is an enterprise-cl...