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


    一、动态树

    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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88
    • 89
    • 90
    • 91
    • 92
    • 93
    • 94
    • 95
    • 96
    • 97
    • 98
    • 99
    • 100
    • 101
    • 102
    • 103
    • 104
    • 105
    • 106
    • 107
    • 108
    • 109
    • 110
    • 111
    • 112
    • 113
    • 114
    • 115
    • 116
    • 117
    • 118
    • 119
    • 120
    • 121
    • 122
    • 123
    • 124
    • 125
    • 126
    • 127
    • 128
    • 129
    • 130

    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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86

    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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68

    在这里插入图片描述

    二、数据表格&分页

    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>
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
    • 84
    • 85
    • 86
    • 87
    • 88

    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
            }
          ]
        }
      ]
    })
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52

    3、运行截图

    在这里插入图片描述
    在这里插入图片描述
    在这里插入图片描述

  • 相关阅读:
    Himall商城- web私有方法
    IEC103设备数据 转 IEC61850项目案例
    RT-Thread Nano系统启动过程研究
    opencv创建窗口—cv.namedWindow()
    springMSV
    【2023华为杯A题】WLAN网络信道接入机制建模(代码、思路.....)
    华清 Qt day4 9月20
    【uniapp】subnvue组件数据更新视图未更新问题
    力扣--深度优先算法/回溯算法78.子集
    npm/yarn link 测试包时报错 Warning: Invalid hook call. Hooks can only be called ...
  • 原文地址:https://blog.csdn.net/weixin_67677668/article/details/126829261