登录+sessionstorage

效果展示

登录成功后会把用户id存入前端的sessionstorage,拦截器会根据是否存在用户id来进行拦截
也可以将用户权限存入sessionstorage,然后当访问某个页面的时候在created方法中判断是否具有权限

<template>
<div class="login-wrap">
<el-form class="login-container" ref="loginformref" :model="loginform">
<h1 class="title">用户登陆</h1>
<el-form-item label="">
<el-input type="text" placeholder="用户账号" v-model="loginform.username" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="">
<el-input type="text" placeholder="用户密码" v-model="loginform.password" autocomplete="off"></el-input>
</el-form-item>
<el-form-item >
<el-radio-group v-model="loginform.resource">
<el-radio label="管理员"></el-radio>
<el-radio label="普通用户"></el-radio>
</el-radio-group>
</el-form-item>
<el-form-item>
<template slot-scope="scope">
<el-button type="primary" @click="dologin()" style="width: 100%;">用户登录</el-button>
<!-- <el-button style="width: 48%;" @click="gotoregister" >用户注册</el-button> -->
</template>
</el-form-item>
<!-- <el-row style="text-align: center;">
<el-link @click="gotoregister()">用户注册</el-link>
<el-link>忘记密码</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 == "管理员") {
const {
data: res
} = await this.axios.post("http://localhost:8088/loginadmin", this.loginform)
if (res) {
this.$message.success("管理员登录成功")
sessionstorage.setitem("personid","ljhjiayou")
this.$router.push({
path: "/dong"
});
} else {
this.$message.error("账号或密码错误")
}
//普通用户登录
}else{
const {
data: res
} = await this.axios.post("http://localhost:8088/loginuser", this.loginform)
if (res) {
console.log(res)
this.$message.success("普通用户登录成功")
sessionstorage.setitem("personid",res)
this.$router.push({
path: "/person"
});
} else {
this.$message.error("账号或密码错误")
}
}
})
}
}
}
</script>
//scoped="scoped" 表示样式仅仅规范当前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>

分页表格

效果展示

分页这一块是难点也是重点!!!
handlesizechange方法选择分页大小
handlecurrentchange方法选择第几页
loaddata调用后端api接口获取分页的数据

<template>
<div>
<el-table :data="tabledata" border style="width: 100%">
<el-table-column fixed prop="id" label="新闻id" width="150">
</el-table-column>
<el-table-column prop="typeid" label="新闻标题" width="200">
</el-table-column>
<el-table-column prop="otherid" label="新闻摘要" width="200"> </el-table-column>
<el-table-column prop="money" label="新闻内容" width="200">
</el-table-column>
<el-table-column prop="datetime" label="新闻发布时间" width="150"> </el-table-column>
<el-table-column fixed="right" label="操作" width="200">
<template slot-scope="scope">
<el-button @click="updateexercise(scope.row)" size="mesdium" type="primary">修改</el-button>
<el-button @click="deleteexercise(scope.row)" type="warning" size="medium">删除</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);
},
//从服务器读取数据
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;
}

开关+标签页

效果展示

开关的主要方法 switchchange
标签页不难,如果看不懂下面代码,可以参考官方文档

前端开关主要代码

<el-table-column prop="name" label="是否冻结" 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>

完整代码

<template>
<el-tabs v-model="activename" @tab-click="handleclick">
<el-tab-pane label="所有账户" name="first">
<el-table :data="tabledata" border style="width: 100%">
<el-table-column fixed prop="accoundid" label="账户id" width="150">
</el-table-column>
<el-table-column prop="password" label="密码" width="200">
</el-table-column>
<el-table-column prop="balance" label="余额" width="200"> </el-table-column>
<el-table-column prop="name" label="是否冻结" 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="操作" width="200">
<template slot-scope="scope">
<el-button @click="deleteexercise(scope.row)" type="warning" size="medium"
>删除</el-button
>
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="被冻结的账户" name="second">
<el-table :data="tabledatab" border style="width: 100%">
<el-table-column fixed prop="accoundid" label="账户id" width="150">
</el-table-column>
<el-table-column prop="personinfo.realname" label="名字" width="200">
</el-table-column>
<el-table-column prop="password" label="密码" width="200">
</el-table-column>
<el-table-column prop="balance" label="余额" width="200"> </el-table-column>
<el-table-column fixed="right" label="操作" width="200">
<template slot-scope="scope">
<el-button @click="qiyong(scope.row)" type="warning" size="medium"
>启用</el-button
>
</template>
</el-table-column>
</el-table>
</el-tab-pane>
<el-tab-pane label="已启用的账户" name="third">
<el-table :data="tabledatabc" border style="width: 100%">
<el-table-column fixed prop="accoundid" label="账户id" width="150">
</el-table-column>
<el-table-column prop="personinfo.realname" label="名字" width="200">
</el-table-column>
<el-table-column prop="password" label="密码" width="200">
</el-table-column>
<el-table-column prop="balance" label="余额" width="200"> </el-table-column>
<el-table-column fixed="right" label="操作" width="200">
<template slot-scope="scope">
<el-button @click="dongjie(scope.row)" type="warning" size="medium"
>冻结</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: "开启成功",
type: "success"
});
// location.reload()
});
} else if (e == 2) {
axios.get('http://localhost:8088/accounts/dongjie/' + data.accoundid).then((res) => {
this.$message({
message: "冻结成功",
type: "success"
});
// location.reload()
});
}
},
dongjie(row) {
let _this=this
this.$confirm('是否确定冻结'+row.personinfo.realname+'的账户?','冻结账户',{
confirmbuttontext: '确定',
cancelbuttontext: '取消',
type: 'warning'
}).then(()=>{
axios.get('http://localhost:8088/accounts/dongjie/'+row.accoundid).then(function (response){
if(response.data){
_this.$alert(row.personinfo.realname+'的账户冻结成功!', '冻结账户',{
confirmbuttontext: '确定',
callback: action =>{
location.reload()
}
});
}
})
}).catch(()=>{
});
},
qiyong(row) {
let _this=this
this.$confirm('是否确定启用'+row.personinfo.realname+'的账户?','启用账户',{
confirmbuttontext: '确定',
cancelbuttontext: '取消',
type: 'warning'
}).then(()=>{
axios.get('http://localhost:8088/accounts/kaiqi/'+row.accoundid).then(function (response){
if(response.data){
_this.$alert(row.personinfo.realname+'的账户启用成功!', '启用账户',{
confirmbuttontext: '确定',
callback: action =>{
location.reload()
}
});
}
})
}).catch(()=>{
});
},
deleteexercise(row) {
let _this=this
this.$confirm('是否确定删除账户'+row.accoundid+'?','删除账户',{
confirmbuttontext: '确定',
cancelbuttontext: '取消',
type: 'warning'
}).then(()=>{
axios.delete('http://localhost:8088/accounts/'+row.accoundid).then(function (response){
if(response.data){
_this.$alert(row.accoundid+'账户删除成功!', '删除账户',{
confirmbuttontext: '确定',
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>

前端拦截器

判断路由是否需要登录权限

main.js

router.beforeeach((to, from, next) => {
// next()
if (to.meta.requireauth) { // 判断该路由是否需要登录权限
if (sessionstorage.getitem("personid")) {
next()
} else {
// 未登录,跳转到登录页面
next('/')
}
} else {
next()
}
})

route.js

在路由中添加 meta: requireauth:true
表示是否需要登录才能访问

{
path: '/listxw',
name: '新闻管理',
component: index,
show: true,
meta: {
requireauth: true
},
redirect: "/listxw",
children: [{
path: "/addxw",
name: "添加新闻",
component: addxw,
meta: {
requireauth: true
},
},
{
path: "/updatexw",
name: "修改新闻",
component: updatexw,
meta: {
requireauth: true
},
},
{
path: '/listxw',
name: '新闻列表',
component: listxw,
meta: {
requireauth: true
},
},
{
path: '/person',
name: '个人信息',
component: person,
meta: {
requireauth: true
},
},
{
path: '/record',
name: '交易记录',
component: record,
meta: {
requireauth: true
},
}
],
},

富文本编辑器

效果展示
下面几个名字是使用了富文本编辑器的回显

首先需要安装vue-quill-editor
命令:npm install vue-quill-editor –save
下载quill(vue-quill-editor需要依赖)
npm install quill –save

完整代码

<template>
<div>
<el-form ref="loginformref" label-width="100px" style="width: 60%" :model="loginform">
<el-form-item label="新闻标题">
<el-input v-model="loginform.title"></el-input>
</el-form-item>
<el-form-item label="新闻摘要">
<el-input v-model="loginform.newsabstract"></el-input>
</el-form-item>
<el-form-item label="新闻内容">
<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()">添加新闻</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"; //调用编辑器
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("添加新闻成功")
this.$router.push({
path: "/listxw"
});
} else {
this.$message.error("添加新闻失败")
}
})
},
oneditorready(editor) { // 准备编辑器
},
oneditorblur() {}, // 失去焦点事件
oneditorfocus() {}, // 获得焦点事件
oneditorchange() {}, // 内容改变事件
// 转码
escapestringhtml(str) {
str = str.replace(/&lt;/g, '<');
str = str.replace(/&gt;/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>'; // 请求后台返回的内容字符串
this.str = this.escapestringhtml(content);
}
};
</script>
<style>
</style>

本地源代码
前端e:\vnc\project\capital_vue
后端e:\vnc\project\capital

到此这篇关于vue中的elementui的使用详解的文章就介绍到这了,更多相关vue elementui 使用内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!