SPA项目之动态树&数据表格&分页

目录

  • 一、动态树
    • 1、修改Login.vue
    • 2、LeftNav.vue
    • 3、AppMain.vue
  • 二、数据表格&分页
    • 1、Articles.vue
    • 2、index.js
    • 3、运行截图

一、动态树

process.env.MOCK && require(‘@/mock’)记得注释

1、修改Login.vue

<template>
  <div class="login-wrap">
    <el-form :model="ruleForm" ref="ruleForm" label-width="100px" class="demo-ruleForm login-container">
      <el-row>
        <el-col :span="24">
          <div style="text-align: center;" class="grid-content bg-purple-dark">
            <h3>用户登录h3>
          div>
        el-col>
      el-row>
      <el-form-item label="用户" prop="uname">
        <el-input type="text" v-model="ruleForm.uname" autocomplete="off">el-input>
      el-form-item>
      <el-form-item label="密码" prop="pwd">
        <el-input type="password" v-model="ruleForm.pwd" autocomplete="off">el-input>
      el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="24">
            <div style="text-align: center;" class="grid-content bg-purple-dark">
              <el-button style="width: 100%;" type="primary" @click="submitForm">提交el-button>
            div>
          el-col>
        el-row>
      el-form-item>
      <el-form-item>
        <el-row>
          <el-col :span="12">
            <div style="text-align: center;" class="grid-content bg-purple-dark">
              <el-link type="success" @click="toReg()">用户注册el-link>
            div>
          el-col>
          <el-col :span="12">
            <div style="text-align: center;" class="grid-content bg-purple-dark">
              <el-link type="warning" @click="">忘记密码el-link>            div>
          el-col>
        el-row>
      el-form-item>
    el-form>
  div>
template>

<script>
export default {
  name: 'Login',
  data () {
    return {
      ruleForm:{}
    }
  },
  methods:{
    submitForm(){
      // this.axios找到的是/api/http.js文件
      //axios.urls = action --> this.axios.urls找到了 /api/action.js文件
      // action.js是一个json对象,那么就可以取到请求的值
      // let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      let url = this.axios.urls.SYSTEM_USER_DOLOGIN;
      // alert(url);
      // {uname:'zs',pwd:'123'}

      /* this.axios.get(url, { //注意数据是保存到json对象的params属性
      	params: this.ruleForm
      }).then(function(response) {
      	console.log(response);
      }).catch(function(error) {
      	console.log(error);
      }); */

      // this指的是vue实例
      this.axios.post(url,this.ruleForm)
      .then(resp => {//代表成功  箭头函数 jdk8
      // .foreach(System.out::print)
        console.log(resp);
        if(resp.data.code==1){
          // this指的是http.js
          this.$message({
            message:resp.data.msg,
            type:'success'
          });
          this.$router.push({path:"/AppMain"})
        }else if(resp.data.code==0){
          // this指的是http.js
          this.$message.error(resp.data.msg);
        }

      }).catch(function(){//代表失败

      });
    },
    resetForm(){

    },
    toReg(){
      this.$router.push({path:'/Reg'})
    }
  }
}
script>

<style 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>

2、LeftNav.vue

<template>
  <el-menu  router :default-active="$route.path" default-active="2" class="el-menu-vertical-demo" background-color="#334157" text-color="#fff"
    active-text-color="#ffd04b" :collapse="collapsed">
    
    <div class="logobox">
      <img class="logoimg" src="../assets/img/logo.png" alt="">
    div>
    <el-submenu v-for="m in menus" :index="'id'+m.treeNodeId">
      <template slot="title">
        <i :class="m.icon">i>
        <span>{{m.treeNodeName}}span>
      template>
      <el-menu-item v-for="m2 in m.children" :key="'id'+m2.treeNodeId" :index="m2.url">
        <i :class="m2.icon">i>
        <span>{{m2.treeNodeName}}span>
      el-menu-item>
    el-submenu>
  el-menu>
template>
<script>
  export default {
    data() {
      return {
        collapsed: false,
        menus:[]
      }
    },
    created() {
      // 从总线上取出this.collapsed变量
      this.$root.Bus.$on('collapsed-side', v => {
        this.collapsed = v;
      });

      // 获取树形节点的数据
      let url = this.axios.urls.SYSTEM_MENU_TREE;

      // this指的是vue实例
      this.axios.post(url,{})
      .then(resp => {//代表成功  箭头函数 jdk8
      // .foreach(System.out::print)
        console.log(resp);
        this.menus = resp.data.result;

      }).catch(function(){//代表失败

      });
    }
  }
script>
<style>
  .el-menu-vertical-demo:not(.el-menu--collapse) {
    width: 240px;
    min-height: 400px;
  }

  .el-menu-vertical-demo:not(.el-menu--collapse) {
    border: none;
    text-align: left;
  }

  .el-menu-item-group__title {
    padding: 0px;
  }

  .el-menu-bg {
    background-color: #1f2d3d !important;
  }

  .el-menu {
    border: none;
  }

  .logobox {
    height: 40px;
    line-height: 40px;
    color: #9d9d9d;
    font-size: 20px;
    text-align: center;
    padding: 20px 0px;
  }

  .logoimg {
    height: 40px;
  }
style>

3、AppMain.vue

<template>
	<el-container class="main-container">
		<el-aside v-bind:class="asideClass">
			<LeftNav>LeftNav>
		el-aside>
		<el-container>
			<el-header class="main-header">
				<TopNav>TopNav>
			el-header>
			<el-main class="main-center">
        <router-view>router-view>
      el-main>
		el-container>
	el-container>
template>

<script>
	// 导入组件
	import TopNav from '@/components/TopNav.vue'
	import LeftNav from '@/components/LeftNav.vue'

	// 导出模块
	export default {
		components:{
      TopNav,LeftNav
    },
    data(){
      return {
        asideClass:'main-aside'
      }
    },
    created(){
      // 从总线上取出this.collapsed变量
      this.$root.Bus.$on('collapsed-side',v => {
        this.asideClass = v ? 'main-aside-collapsed' : 'main-aside';
      });
    }
	};
script>
<style scoped>
	.main-container {
		height: 100%;
		width: 100%;
		box-sizing: border-box;
	}

	.main-aside-collapsed {
		/* 在CSS中,通过对某一样式声明! important ,可以更改默认的CSS样式优先级规则,使该条样式属性声明具有最高优先级 */
		width: 64px !important;
		height: 100%;
		background-color: #334157;
		margin: 0px;
	}

	.main-aside {
		width: 240px !important;
		height: 100%;
		background-color: #334157;
		margin: 0px;
	}

	.main-header,
	.main-center {
		padding: 0px;
		border-left: 2px solid #333;
	}
style>

SPA项目之动态树&数据表格&分页_第1张图片

二、数据表格&分页

1、Articles.vue

<template>
	<div>
		<el-form :inline="true" :model="formInline" class="user-search">
			<el-form-item label="搜索:">
				<el-input size="small" v-model="formInline.title" placeholder="输入文章标题">el-input>
			el-form-item>
			<el-form-item>
				<el-button size="small" type="primary" icon="el-icon-search" @click="search">搜索el-button>
				
			el-form-item>
		el-form>
		
		<el-table size="small" :data="listData" element-loading-text="拼命加载中" style="width: 100%;">
			<el-table-column align="center" type="selection" min-width="1">
			el-table-column>
			<el-table-column sortable prop="id" label="文章ID" min-width="1">
			el-table-column>
			<el-table-column sortable prop="title" label="文章标题" min-width="3">
			el-table-column>
			<el-table-column sortable prop="body" label="文章内容" min-width="5">
			el-table-column>
			
		el-table>
		<el-pagination style="margin-top: 20px;" @size-change="handleSizeChange" @current-change="handleCurrentChange"
		 :current-page="formInline.page" :page-sizes="[10, 20, 30, 50]" :page-size="100" layout="total, sizes, prev, pager, next, jumper"
		 :total="total">
		el-pagination>
	div>
template>


<script>
 export default {
 		data() {
 			return {
 				listData: [],
 				formInline: {
 					page: 1,
 					rows: 10,
 					title: ''
 				},
 				total: 0
 			};
 		},
 		methods: {

 			handleSizeChange(rows) {
 				this.formInline.page = 1;
 				this.formInline.rows = rows;
 				this.search();
 			},
 			handleCurrentChange(page) {
 				this.formInline.page = page;
 				this.search();
 			},
 			doSearch(params) {
 				let url = this.axios.urls.SYSTEM_ARTICLE_LIST;
 				// let url = 'http://localhost:8080/T216_SSH/vue/userAction_login.action';

 				this.axios.post(url, params).then((response) => {
 					console.log(response);
 					this.listData = response.data.result;
 					this.total = response.data.pageBean.total;
 				}).catch(function(error) {
 					console.log(error);
 				});
 			},
 			search(){
 				this.doSearch(this.formInline);
 			}
 		},
 		created() {
 			this.doSearch({});
 		}
 	}


script>

<style>

style>

2、index.js

import Vue from 'vue'
import Router from 'vue-router'
import HelloWorld from '@/components/HelloWorld'
import AppMain from '@/components/AppMain'
import LeftNav from '@/components/LeftNav'
import TopNav from '@/components/TopNav'
import Login from '@/views/Login'
import Reg from '@/views/Reg'
import Articles from '@/views/sys/Articles'

Vue.use(Router)

export default new Router({
  routes: [{
      path: '/',
      name: 'Login',
      component: Login
    },
    {
      path: '/Login',
      name: 'Login',
      component: Login
    },
    {
      path: '/Reg',
      name: 'Reg',
      component: Reg
    },
    {
      path: '/AppMain',
      name: 'AppMain',
      component: AppMain,
      children: [{
          path: '/LeftNav',
          name: 'LeftNav',
          component: LeftNav
        },
        {
          path: '/TopNav',
          name: 'TopNav',
          component: TopNav
        },
        {
          path: '/sys/Articles',
          name: 'Articles',
          component: Articles
        }
      ]
    }
  ]
})

3、运行截图

SPA项目之动态树&数据表格&分页_第2张图片
在这里插入图片描述
SPA项目之动态树&数据表格&分页_第3张图片

你可能感兴趣的:(javascript,前端,vue.js)