vue的ElemenUI的使用

登录+sessionStorage

效果展示
vue的ElemenUI的使用_第1张图片

<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>
					
				template>
			el-form-item>
			
		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>

分页表格

效果展示
vue的ElemenUI的使用_第2张图片

<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;
    }

参考链接

开关+标签页

效果展示
vue的ElemenUI的使用_第3张图片



前端拦截器

main.js

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

route.js

{
		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
				},
			
			}
		],
	},

本地源代码
前端E:\VNC\project\capital_vue
后端E:\VNC\project\capital

你可能感兴趣的:(vue,vue.js,vue,elementui,html5)