ElementUI 홈페이지 탐색 및 왼쪽 메뉴(시뮬레이션 구현)

목차

편집하다

머리말

1. mockjs 소개

1. mockjs란 무엇인가

2. mockjs의 목적

3. mockjs를 활용하세요

2. mockjs 설치 및 구성

1. mockjs 설치

2. mockjs 소개

2.1 dev.env.js

2.2 prod.env.js

2.3 메인.js

3. mockjs 사용

1. 리소스의 모의 폴더를 src 디렉터리에 복사합니다.

2. 시뮬레이션 테스트를 위해 로그인을 클릭하세요.

4. 버스 건설

1. 사례도 시연

2. 구성요소 생성

AppMain.vue

왼쪽Nav.vue

TopNav.vue

3. 라우팅과 구성 요소 간의 관계를 구성합니다.

index.js

4. 로그인을 실현하고 홈페이지로 이동합니다.

5. 최종 코드

AppMain.vue

왼쪽Nav.vue

TopNav.vue

main.js

최종 시연 효과


머리말

       이전 블로그에서 저는 Vue에 대한 몇 가지 지식을 여러분과 공유했으며 이를 통해 로그인 등록을 구현하는 ElementUI, SPA 프로젝트 구축, 라우팅 등을 위한 vue-cli와 같은 몇 가지 도움과 이득을 얻었을 것입니다. 오늘은 홈페이지 내비게이션과 왼쪽 메뉴 모듈을 구성하는 Element를 소개하겠습니다.

1. mockjs 소개

1. mockjs란 무엇인가

        MockJS는 프런트 엔드 개발에 일반적으로 사용되는 시뮬레이션 데이터 생성 도구로 , 개발 프로세스 중에 인터페이스 반환 데이터를 시뮬레이션하는 데 사용됩니다. 이를 통해 프런트엔드 개발자는 백엔드 인터페이스와 독립적으로 개발 및 디버그하여 개발 효율성을 높일 수 있습니다. MockJS는 지정된 규칙에 따라 무작위 시뮬레이션 데이터를 생성할 수 있는 간단하지만 강력한 API를 제공합니다. MockJS를 통해 개발자 는 문자열 길이, 숫자 범위, 날짜 형식 등과 같은 인터페이스의 반환 구조, 데이터 유형 및 다양한 제약 조건을 정의하여 실제 인터페이스 반환 결과를 시뮬레이션할 수 있습니다 .

        MockJS의 사용은 매우 유연하며 다른 프런트 엔드 프레임워크(예: Vue, React, Angular) 또는 순수 JavaScript와 통합될 수 있습니다 . 또한 브라우저 환경과 Node.js 서버 환경에서의 실행을 지원하며 다양한 시나리오에서 데이터 요구 사항을 시뮬레이션하는 데 적합합니다.

        MockJS를 사용하면 개발자는 프런트 엔드 개발 환경을 신속하게 설정하고, 독립적으로 개발 및 디버그할 수 있으며, 백엔드 인터페이스가 불완전하거나 사용할 수 없는 경우에도 프로젝트의 정상적인 진행을 계속 유지할 수 있습니다. 동시에 MockJS를 사용하여 인터페이스 테스트 및 디버깅을 용이하게 하는 자동화된 테스트 케이스를 작성할 수도 있습니다.

2. mockjs의 목적

        Mock.js는 프런트엔드 개발자가 시뮬레이션 데이터를 신속하게 생성하여 프런트엔드 개발과 프런트엔드 및 백엔드 분리 개발을 촉진하는 데 도움이 되는 시뮬레이션 데이터 생성기입니다. 특정 애플리케이션 시나리오는 다음과 같습니다.

  1. 프런트엔드 개발 중에 Mock.js를 사용하면 백엔드 인터페이스 구현에 의존하지 않고도 프런트엔드 기능 개발 및 디버깅을 용이하게 하기 위해 시뮬레이션된 인터페이스 데이터를 생성할 수 있습니다.

  2. 프론트엔드와 백엔드를 별도로 개발할 경우, 프론트엔드는 Mock.js에서 제공하는 시뮬레이션 데이터 생성 기능을 활용하여 언제 어디서나 개발하고 테스트할 수 있습니다. 백엔드 인터페이스가 완료되면 구성을 변경하고 Mock.js를 백엔드 인터페이스의 요청으로 바꾸십시오.

  3. 온라인 교육 플랫폼과 같이 대량의 테스트 데이터가 필요한 애플리케이션 시나리오에서 Mock.js를 사용하면 테스트 및 시연을 위해 대량의 무작위 데이터를 생성할 수 있습니다.

  4. 백엔드 인터페이스가 아직 개발되지 않은 프로젝트 초기 단계에서 Mock.js를 사용하여 시뮬레이션 데이터를 생성하여 프런트엔드 프로젝트에 일부 데이터 표시 효과를 제공할 수 있습니다.

3. mockjs를 활용하세요

장점은 주로 다음과 같습니다.

  1. 풍부한 데이터 유형 : MockJS는 임의의 텍스트, 숫자, 부울 값, 날짜, 이메일, 링크, 그림, 색상 등의 생성을 지원하여 개발 프로세스 중 다양한 데이터 상황을 시뮬레이션하고 개발자가 더 나은 테스트 및 디버깅을 하도록 돕습니다.
  2. Ajax 요청 가로채기 : MockJS는 기존 코드를 수정하지 않고도 Ajax 요청을 가로채고 시뮬레이션된 응답 데이터를 반환할 수 있습니다. 이는 개발 중 서버 응답을 시뮬레이션하거나 로컬 테스트에 매우 유용합니다.
  3. 프론트엔드와 백엔드 분리 : MockJS는 프론트엔드가 백엔드와 독립적으로 개발되도록 도울 수 있습니다. 이는 프론트엔드와 백엔드 분리 개발 모델에 매우 유익하며 개발 진행 속도를 높이고 개선할 수 있습니다. 능률.
  4. 단위 테스트 : MockJS의 무작위 데이터 시뮬레이션 기능은 개발자가 단위 테스트에서 테스트의 신뢰성을 높이고 다양한 시나리오를 시뮬레이션하여 테스트의 무결성과 신뢰성을 향상시키는 데 도움이 될 수 있습니다.
  5. Non-intrusive : MockJS는 기존 코드를 수정하지 않고 가로채고 시뮬레이션할 수 있으며, 프런트 엔드 개발 중 인터페이스 테스트와 같이 프로덕션 코드를 수정하고 싶지 않은 시나리오에 매우 적합합니다.
  6. 간단하고 사용하기 쉬움 : MockJS의 인터페이스는 직관적이고 사용하기 쉬우므로 개발자가 빠르게 시작하고 사용할 수 있습니다.
  7. 편리한 확장 : MockJS는 더 많은 데이터 유형, 사용자 정의 함수 및 정규 표현식의 확장을 지원하므로 MockJS가 더 많은 개발 요구 사항을 충족할 수 있습니다. 둘,

2. mockjs 설치 및 구성

1. mockjs 설치

프로젝트 디렉토리에 cmd 터미널 창에 진입하여 다음 지시 사항을 입력하여 설치합니다.

npm 나는 mockjs -D

참고: -D는 개발 환경에서만 사용됨을 의미합니다.

2. mockjs 소개

2.1  dev.env.js

module.exports = merge(prodEnv, {
  NODE_ENV: '"development"',
	MOCK: 'true'
})

2.2   prod.env.js

module.exports = {
  NODE_ENV: '"production"',
	MOCK: 'false'
}

2.3  메인.js

개발 환경에서만 사용되고 프로덕션 환경에서는 사용되지 않는 동적 main.js에 mockjs를 로드합니다.

//开发环境下才会引入mockjs
process.env.MOCK && require('@/mock') 

3. mockjs 사용

1. 리소스의 모의 폴더를 src 디렉터리에 복사합니다.

 이 파일 아래 json 폴더에 있는 login-mock.js는 시뮬레이션 데이터를 생성하는 데 사용되며, index.js는 데이터를 로그인 요청에 바인딩하는 데 사용됩니다.

2. 시뮬레이션 테스트를 위해 로그인을 클릭하세요.

 여러 번 클릭하여 로그인하면 코드가 변경(-1/0)될 수 있지만 메시지 길이는 달라집니다.

 백엔드 상호작용 없이 현재 로그인의 성공과 실패를 시뮬레이션합니다.

Login.vue

<template>
  <div class="login">

    <template>
      <div class="login-wrap">
        <el-form class="login-container">
          <h1 class="title">君易官网登录</h1>
          <el-form-item label="">
            <el-input type="text" v-model="username" placeholder="登录账号" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item label="">
            <el-input type="password" v-model="password" placeholder="登录密码" autocomplete="off"></el-input>
          </el-form-item>
          <el-form-item>
            <el-button type="primary" style="width:100%;" @click="doSubmit()">提交</el-button>
          </el-form-item>
          <el-row style="text-align: center;margin-top:-10px">
            <el-link type="primary">忘记密码</el-link>
            <el-link type="primary" @click="gotoRegister()">用户注册</el-link>
          </el-row>
        </el-form>
      </div>
    </template>

  </div>


</template>

<script>
  // import axios from 'axios'
  // import qs from 'qs'
  export default {
    name: 'Login',
    data() {
      return {
        msg: 'Welcome to Your Vue.js App',
        username: '',
        password: ''
      }
    },
    methods: {
      gotoRegister() {
        // 跳转注册页面
        this.$router.push('/Register');
      },
      doSubmit() {
        // 接受参数
        let params = {
          username : this.username,
          password : this.password
        };
        // 打印输出查看
        console.log(params);
        // 定义请求参数的访问地址
        var url = this.axios.urls.SYSTEM_USER_DOLOGIN;
        // 想后端发送post请求
        this.axios.post(url, params).then(r => {
          // 打印
          console.log(r);
          // 输入的账号密码正确则弹出登陆成功提示,反之弹出密码或账号有误提示
          // if (r.data.success) {
          //   this.$message({
          //     message: r.data.msg,
          //     type: 'success'
          //   });
          // } else {
          //   this.$message.error(r.data.msg);
          // }
          this.$message({
              message: r.data.message,
              type: r.data.code ==0 ? 'success' : 'error'
            });

        }).catch(e => {
          console.log(e);
        });

      }

    }
  }
</script>

<style scoped>
  .login-wrap {
    box-sizing: border-box;
    width: 100%;
    height: 100%;
    padding-top: 10%;
    background-image: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8" standalone="no"?>
<svg width="1361px" height="609px" viewBox="0 0 1361 609" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
    <!-- Generator: Sketch 46.2 (44496) - http://www.bohemiancoding.com/sketch -->
    <title>Group 21</title>
    <desc>Created with Sketch.</desc>
    <defs></defs>
    <g id="Ant-Design-Pro-3.0" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">
        <g id="账户密码登录-校验" transform="translate(-79.000000, -82.000000)">
            <g id="Group-21" transform="translate(77.000000, 73.000000)">
                <g id="Group-18" opacity="0.8" transform="translate(74.901416, 569.699158) rotate(-7.000000) translate(-74.901416, -569.699158) translate(4.901416, 525.199158)">
                    <ellipse id="Oval-11" fill="#CFDAE6" opacity="0.25" cx="63.5748792" cy="32.468367" rx="21.7830479" ry="21.766008"></ellipse>
                    <ellipse id="Oval-3" fill="#CFDAE6" opacity="0.599999964" cx="5.98746479" cy="13.8668601" rx="5.2173913" ry="5.21330997"></ellipse>
                    <path d="M38.1354514,88.3520215 C43.8984227,88.3520215 48.570234,83.6838647 48.570234,77.9254015 C48.570234,72.1669383 43.8984227,67.4987816 38.1354514,67.4987816 C32.3724801,67.4987816 27.7006688,72.1669383 27.7006688,77.9254015 C27.7006688,83.6838647 32.3724801,88.3520215 38.1354514,88.3520215 Z" id="Oval-3-Copy" fill="#CFDAE6" opacity="0.45"></path>
                    <path d="M64.2775582,33.1704963 L119.185836,16.5654915" id="Path-12" stroke="#CFDAE6" stroke-width="1.73913043" stroke-linecap="round" stroke-linejoin="round"></path>
                    <path d="M42.1431708,26.5002681 L7.71190162,14.5640702" id="Path-16" stroke="#E0B4B7" stroke-width="0.702678964" opacity="0.7" stroke-linecap="round" stroke-linejoin="round" stroke-dasharray="1.405357899873153,2.108036953469981"></path>
                    <path d="M63.9262187,33.521561 L43.6721326,69.3250951" id="Path-15" stroke="#BACAD9" stroke-width="0.702678964" stroke-linecap="round" stroke-linejoin="round" stroke-dasharray="1.405357899873153,2.108036953469981"></path>
                    <g id="Group-17" transform="translate(126.850922, 13.543654) rotate(30.000000) translate(-126.850922, -13.543654) translate(117.285705, 4.381889)" fill="#CFDAE6">
                        <ellipse id="Oval-4" opacity="0.45" cx="9.13482653" cy="9.12768076" rx="9.13482653" ry="9.12768076"></ellipse>
                        <path d="M18.2696531,18.2553615 C18.2696531,13.2142826 14.1798519,9.12768076 9.13482653,9.12768076 C4.08980114,9.12768076 0,13.2142826 0,18.2553615 L18.2696531,18.2553615 Z" id="Oval-4" transform="translate(9.134827, 13.691521) scale(-1, -1) translate(-9.134827, -13.691521) "></path>
                    </g>
                </g>
                <g id="Group-14" transform="translate(216.294700, 123.725600) rotate(-5.000000) translate(-216.294700, -123.725600) translate(106.294700, 35.225600)">
                    <ellipse id="Oval-2" fill="#CFDAE6" opacity="0.25" cx="29.1176471" cy="29.1402439" rx="29.1176471" ry="29.1402439"></ellipse>
                    <ellipse id="Oval-2" fill="#CFDAE6" opacity="0.3" cx="29.1176471" cy="29.1402439" rx="21.5686275" ry="21.5853659"></ellipse>
                    <ellipse id="Oval-2-Copy" stroke="#CFDAE6" opacity="0.4" cx="179.019608" cy="138.146341" rx="23.7254902" ry="23.7439024"></ellipse>
                    <ellipse id="Oval-2" fill="#BACAD9" opacity="0.5" cx="29.1176471" cy="29.1402439" rx="10.7843137" ry="10.7926829"></ellipse>
                    <path d="M29.1176471,39.9329268 L29.1176471,18.347561 C23.1616351,18.347561 18.3333333,23.1796097 18.3333333,29.1402439 C18.3333333,35.1008781 23.1616351,39.9329268 29.1176471,39.9329268 Z" id="Oval-2" fill="#BACAD9"></path>
                    <g id="Group-9" opacity="0.45" transform="translate(172.000000, 131.000000)" fill="#E6A1A6">
                        <ellipse id="Oval-2-Copy-2" cx="7.01960784" cy="7.14634146" rx="6.47058824" ry="6.47560976"></ellipse>
                        <path d="M0.549019608,13.6219512 C4.12262681,13.6219512 7.01960784,10.722722 7.01960784,7.14634146 C7.01960784,3.56996095 4.12262681,0.670731707 0.549019608,0.670731707 L0.549019608,13.6219512 Z" id="Oval-2-Copy-2" transform="translate(3.784314, 7.146341) scale(-1, 1) translate(-3.784314, -7.146341) "></path>
                    </g>
                    <ellipse id="Oval-10" fill="#CFDAE6" cx="218.382353" cy="138.685976" rx="1.61764706" ry="1.61890244"></ellipse>
                    <ellipse id="Oval-10-Copy-2" fill="#E0B4B7" opacity="0.35" cx="179.558824" cy="175.381098" rx="1.61764706" ry="1.61890244"></ellipse>
                    <ellipse id="Oval-10-Copy" fill="#E0B4B7" opacity="0.35" cx="180.098039" cy="102.530488" rx="2.15686275" ry="2.15853659"></ellipse>
                    <path d="M28.9985381,29.9671598 L171.151018,132.876024" id="Path-11" stroke="#CFDAE6" opacity="0.8"></path>
                </g>
                <g id="Group-10" opacity="0.799999952" transform="translate(1054.100635, 36.659317) rotate(-11.000000) translate(-1054.100635, -36.659317) translate(1026.600635, 4.659317)">
                    <ellipse id="Oval-7" stroke="#CFDAE6" stroke-width="0.941176471" cx="43.8135593" cy="32" rx="11.1864407" ry="11.2941176"></ellipse>
                    <g id="Group-12" transform="translate(34.596774, 23.111111)" fill="#BACAD9">
                        <ellipse id="Oval-7" opacity="0.45" cx="9.18534718" cy="8.88888889" rx="8.47457627" ry="8.55614973"></ellipse>
                        <path d="M9.18534718,17.4450386 C13.8657264,17.4450386 17.6599235,13.6143199 17.6599235,8.88888889 C17.6599235,4.16345787 13.8657264,0.332739156 9.18534718,0.332739156 L9.18534718,17.4450386 Z" id="Oval-7"></path>
                    </g>
                    <path d="M34.6597385,24.809694 L5.71666084,4.76878945" id="Path-2" stroke="#CFDAE6" stroke-width="0.941176471"></path>
                    <ellipse id="Oval" stroke="#CFDAE6" stroke-width="0.941176471" cx="3.26271186" cy="3.29411765" rx="3.26271186" ry="3.29411765"></ellipse>
                    <ellipse id="Oval-Copy" fill="#F7E1AD" cx="2.79661017" cy="61.1764706" rx="2.79661017" ry="2.82352941"></ellipse>
                    <path d="M34.6312443,39.2922712 L5.06366663,59.785082" id="Path-10" stroke="#CFDAE6" stroke-width="0.941176471"></path>
                </g>
                <g id="Group-19" opacity="0.33" transform="translate(1282.537219, 446.502867) rotate(-10.000000) translate(-1282.537219, -446.502867) translate(1142.537219, 327.502867)">
                    <g id="Group-17" transform="translate(141.333539, 104.502742) rotate(275.000000) translate(-141.333539, -104.502742) translate(129.333539, 92.502742)" fill="#BACAD9">
                        <circle id="Oval-4" opacity="0.45" cx="11.6666667" cy="11.6666667" r="11.6666667"></circle>
                        <path d="M23.3333333,23.3333333 C23.3333333,16.8900113 18.1099887,11.6666667 11.6666667,11.6666667 C5.22334459,11.6666667 0,16.8900113 0,23.3333333 L23.3333333,23.3333333 Z" id="Oval-4" transform="translate(11.666667, 17.500000) scale(-1, -1) translate(-11.666667, -17.500000) "></path>
                    </g>
                    <circle id="Oval-5-Copy-6" fill="#CFDAE6" cx="201.833333" cy="87.5" r="5.83333333"></circle>
                    <path d="M143.5,88.8126685 L155.070501,17.6038544" id="Path-17" stroke="#BACAD9" stroke-width="1.16666667"></path>
                    <path d="M17.5,37.3333333 L127.466252,97.6449735" id="Path-18" stroke="#BACAD9" stroke-width="1.16666667"></path>
                    <polyline id="Path-19" stroke="#CFDAE6" stroke-width="1.16666667" points="143.902597 120.302281 174.935455 231.571342 38.5 147.510847 126.366941 110.833333"></polyline>
                    <path d="M159.833333,99.7453842 L195.416667,89.25" id="Path-20" stroke="#E0B4B7" stroke-width="1.16666667" opacity="0.6"></path>
                    <path d="M205.333333,82.1372105 L238.719406,36.1666667" id="Path-24" stroke="#BACAD9" stroke-width="1.16666667"></path>
                    <path d="M266.723424,132.231988 L207.083333,90.4166667" id="Path-25" stroke="#CFDAE6" stroke-width="1.16666667"></path>
                    <circle id="Oval-5" fill="#C1D1E0" cx="156.916667" cy="8.75" r="8.75"></circle>
                    <circle id="Oval-5-Copy-3" fill="#C1D1E0" cx="39.0833333" cy="148.75" r="5.25"></circle>
                    <circle id="Oval-5-Copy-2" fill-opacity="0.6" fill="#D1DEED" cx="8.75" cy="33.25" r="8.75"></circle>
                    <circle id="Oval-5-Copy-4" fill-opacity="0.6" fill="#D1DEED" cx="243.833333" cy="30.3333333" r="5.83333333"></circle>
                    <circle id="Oval-5-Copy-5" fill="#E0B4B7" cx="175.583333" cy="232.75" r="5.25"></circle>
                </g>
            </g>
        </g>
    </g>
</svg>);
    /* 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>

 실행 결과

4. 버스 건설

1. 사례도 시연

2. 구성요소 생성

사례 데모 다이어그램에서 볼 수 있듯이 효과 구성을 완료하려면 세 가지 구성 요소를 생성해야 하며, 세 가지 구성 요소는 공개 부분이므로 구성 요소 파일에 복사하고 자산 파일 아래에 필요한 이미지를 배치합니다.

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">Main</el-main>
		</el-container>
	</el-container>
</template>

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

	// 导出模块
	export default {
		
	};
</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>

왼쪽Nav.vue

<template>
	<el-menu default-active="2" class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose" background-color="#334157"
	 text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed" :collapse-transition="bb">
		<!-- <el-menu default-active="2" :collapse="collapsed" collapse-transition router :default-active="$route.path" unique-opened class="el-menu-vertical-demo" background-color="#334157" text-color="#fff" active-text-color="#ffd04b"> -->
		<div class="logobox">
			<img class="logoimg" src="../assets/img/logo.png" alt="">
		</div>
		<el-submenu index="1">
			<template slot="title">
				<i class="el-icon-location"></i>
				<span>导航一</span>
			</template>
			<el-menu-item-group>
				<template slot="title">分组一</template>
				<el-menu-item index="1-1">选项1</el-menu-item>
				<el-menu-item index="1-2">选项2</el-menu-item>
			</el-menu-item-group>
			<el-menu-item-group title="分组2">
				<el-menu-item index="1-3">选项3</el-menu-item>
			</el-menu-item-group>
			<el-submenu index="1-4">
				<template slot="title">选项4</template>
				<el-menu-item index="1-4-1">选项1</el-menu-item>
			</el-submenu>
		</el-submenu>
		<el-menu-item index="2">
			<i class="el-icon-menu"></i>
			<span slot="title">导航二</span>
		</el-menu-item>
		<el-menu-item index="3" disabled>
			<i class="el-icon-document"></i>
			<span slot="title">导航三</span>
		</el-menu-item>
		<el-menu-item index="4">
			<i class="el-icon-setting"></i>
			<span slot="title">导航四</span>
		</el-menu-item>
	</el-menu>
</template>
<script>
	export default {
		
	}
</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>

TopNav.vue

<template>
	<!-- <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64"
	 text-color="#fff" active-text-color="#ffd04b">
		<el-menu-item index="1">处理中心</el-menu-item>
		<el-submenu index="2">
			<template slot="title">我的工作台</template>
			<el-menu-item index="2-1">选项1</el-menu-item>
			<el-menu-item index="2-2">选项2</el-menu-item>
			<el-menu-item index="2-3">选项3</el-menu-item>
			<el-submenu index="2-4">
				<template slot="title">选项4</template>
				<el-menu-item index="2-4-1">选项1</el-menu-item>
				<el-menu-item index="2-4-2">选项2</el-menu-item>
				<el-menu-item index="2-4-3">选项3</el-menu-item>
			</el-submenu>
		</el-submenu>

		<el-menu-item index="3" disabled>消息中心</el-menu-item>
		<el-menu-item index="4"><a href="https://www.ele.me" target="_blank">订单管理</a></el-menu-item>
	</el-menu> -->
	<el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
		<el-button class="buttonimg">
			<img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
		</el-button>
		<el-submenu index="2" class="submenu">
			<template slot="title">超级管理员</template>
			<el-menu-item index="2-1">设置</el-menu-item>
			<el-menu-item index="2-2">个人中心</el-menu-item>
			<el-menu-item @click="exit()" index="2-3">退出</el-menu-item>
		</el-submenu>
	</el-menu>
</template>

<script>
	export default {
		
	}
</script>

<style scoped>
	.el-menu-vertical-demo:not(.el-menu--collapse) {
		border: none;
	}

	.submenu {
		float: right;
	}

	.buttonimg {
		height: 60px;
		background-color: transparent;
		border: none;
	}

	.showimg {
		width: 26px;
		height: 26px;
		position: absolute;
		top: 17px;
		left: 17px;
	}

	.showimg:active {
		border: none;
	}
</style>

3. 라우팅과 구성 요소 간의 관계를 구성합니다.

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 Register from '@/views/Register'

Vue.use(Router)

export default new Router({
  routes: [ //默认首页
    {
      path: '/',
      name: 'Login',
      component: Login
    }, {
      path: '/Register',
      name: 'Register',
      component: Register
    }, {
      path: '/Login',
      name: 'Login',
      component: Login
    }, {
      path: '/AppMain',
      name: 'AppMain',
      component: AppMain,
      children;
      [{
        path: '/LeftNav',
        name: 'LeftNav',
        component: LeftNav
      }, {
        path: '/TopNav',
        name: 'TopNav',
        component: TopNav
      }]
    }
  ]
})

4. 로그인을 실현하고 홈페이지로 이동합니다.

 this.$router.push('/AppMain');

 

 이것은 반제품일 뿐이며 스타일과 효과를 보여주기 위해 나중에 조정해야 합니다.

5. 최종 코드

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">Main</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.$root.Bus.$on('xxx',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>

왼쪽Nav.vue

<template>
	<el-menu default-active="2" class="el-menu-vertical-demo"  background-color="#334157"
	 text-color="#fff" active-text-color="#ffd04b" :collapse="collapsed" >
		<!-- <el-menu default-active="2" :collapse="collapsed" collapse-transition router :default-active="$route.path" unique-opened class="el-menu-vertical-demo" background-color="#334157" text-color="#fff" active-text-color="#ffd04b"> -->
		<div class="logobox">
			<img class="logoimg" src="../assets/img/logo.png" alt="">
		</div>
		<el-submenu index="1">
			<template slot="title">
				<i class="el-icon-location"></i>
				<span>导航一</span>
			</template>
			<el-menu-item-group>
				<template slot="title">分组一</template>
				<el-menu-item index="1-1">选项1</el-menu-item>
				<el-menu-item index="1-2">选项2</el-menu-item>
			</el-menu-item-group>
			<el-menu-item-group title="分组2">
				<el-menu-item index="1-3">选项3</el-menu-item>
			</el-menu-item-group>
			<el-submenu index="1-4">
				<template slot="title">选项4</template>
				<el-menu-item index="1-4-1">选项1</el-menu-item>
			</el-submenu>
		</el-submenu>
		<el-menu-item index="2">
			<i class="el-icon-menu"></i>
			<span slot="title">导航二</span>
		</el-menu-item>
		<el-menu-item index="3" disabled>
			<i class="el-icon-document"></i>
			<span slot="title">导航三</span>
		</el-menu-item>
		<el-menu-item index="4">
			<i class="el-icon-setting"></i>
			<span slot="title">导航四</span>
		</el-menu-item>
	</el-menu>
</template>
<script>
	export default {
		data() {
		  return{
		    collapsed:false
		  }
		},created(){
    this.$root.Bus.$on('xxx',v=>{
    this.collapsed = v;
    });
    }
	}
</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>

TopNav.vue

<template>
  <!-- <el-menu :default-active="activeIndex2" class="el-menu-demo" mode="horizontal" @select="handleSelect" background-color="#545c64"
	 text-color="#fff" active-text-color="#ffd04b">
		<el-menu-item index="1">处理中心</el-menu-item>
		<el-submenu index="2">
			<template slot="title">我的工作台</template>
			<el-menu-item index="2-1">选项1</el-menu-item>
			<el-menu-item index="2-2">选项2</el-menu-item>
			<el-menu-item index="2-3">选项3</el-menu-item>
			<el-submenu index="2-4">
				<template slot="title">选项4</template>
				<el-menu-item index="2-4-1">选项1</el-menu-item>
				<el-menu-item index="2-4-2">选项2</el-menu-item>
				<el-menu-item index="2-4-3">选项3</el-menu-item>
			</el-submenu>
		</el-submenu>

		<el-menu-item index="3" disabled>消息中心</el-menu-item>
		<el-menu-item index="4"><a href="https://www.ele.me" target="_blank">订单管理</a></el-menu-item>
	</el-menu> -->
  <el-menu class="el-menu-demo" mode="horizontal" background-color="#334157" text-color="#fff" active-text-color="#fff">
    <el-button class="buttonimg">
      <img class="showimg" :src="collapsed?imgshow:imgsq" @click="doToggle()">
    </el-button>
    <el-submenu index="2" class="submenu">
      <template slot="title">超级管理员</template>
      <el-menu-item index="2-1">设置</el-menu-item>
      <el-menu-item index="2-2">个人中心</el-menu-item>
      <el-menu-item @click="exit()" index="2-3">退出</el-menu-item>
    </el-submenu>
  </el-menu>
</template>

<script>
  export default {
    data() {
      return {
        collapsed: false,
        imgshow: require('@/assets/img/show.png'),
        imgsq: require('@/assets/img/sq.png')
      }
    },
    methods: {
      doToggle(){
      this.collapsed = !this.collapsed;
      // 将是否折叠的变量放入总线
      this.$root.Bus.$emit('xxx',this.collapsed);
      },
      exit(){
        this.$router.push("/");
      }
    }
  }
</script>

<style scoped>
  .el-menu-vertical-demo:not(.el-menu--collapse) {
    border: none;
  }

  .submenu {
    float: right;
  }

  .buttonimg {
    height: 60px;
    background-color: transparent;
    border: none;
  }

  .showimg {
    width: 26px;
    height: 26px;
    position: absolute;
    top: 17px;
    left: 17px;
  }

  .showimg:active {
    border: none;
  }
</style>

main.js

// The Vue build version to load with the `import` command
// (runtime-only or standalone) has been set in webpack.base.conf with an alias.
import Vue from 'vue'

//开发环境下才会引入mockjs
process.env.MOCK && require('@/mock')

// 新添加1
import ElementUI from 'element-ui'
// 新添加2,避免后期打包样式不同,要放在import App from './App';之前
import 'element-ui/lib/theme-chalk/index.css'

import App from './App'
import router from './router'

Vue.use(ElementUI);


import axios from '@/api/http'
import VueAxios from 'vue-axios'

Vue.use(VueAxios,axios)

Vue.config.productionTip = false

/* eslint-disable no-new */
new Vue({
  el: '#app',
  router,
  data(){
    return{
      Bus:new Vue()
    }
  },
  components: { App },
  template: '<App/>'
})

최종 시연 효과

버스의 기본 이용방법입니다 

         이 블로그에서는 mockjs와 버스의 일부 사용법을 공유하고 프로젝트에서의 사용법을 보여줍니다. 블로거를 팔로우하고 지원해 주시기 바랍니다. 프로젝트는 앞으로 확장되고 개선될 예정이니 계속 지켜봐 주시기 바랍니다.

추천

출처blog.csdn.net/weixin_74352229/article/details/133277066