>웹 프론트엔드 >View.js >vue3 컨테이너 레이아웃 및 탐색 라우팅을 구현하는 방법

vue3 컨테이너 레이아웃 및 탐색 라우팅을 구현하는 방법

WBOY
WBOY앞으로
2023-05-28 20:08:321268검색

컨테이너 레이아웃

App.vue에서 HelloWorld 관련 콘텐츠에 댓글을 달거나 삭제한 다음, element-plus에서 제공하는 레이아웃을 복사하여 App.vue에 배치하세요

레이아웃은 왼쪽 메뉴바, 오른쪽 콘텐츠 영역, 오른쪽 상단 상단은 전형적인 관리 백엔드 스타일

<template>
  <!-- <img alt="Vue logo" src="./assets/logo.png"> -->
  <div class="common-layout">
    <el-container>
      <el-aside width="200px">
        <Menu></Menu>
      </el-aside>
      <el-container>
        <el-header height="20px">Header</el-header>
        <el-main>
          <router-view></router-view>
        </el-main>
      </el-container>
    </el-container>
  </div>
<!-- 
  <div>
      <p>
        <router-link to="/home">Go to Home</router-link>
        

        <router-link to="/about">Go to about</router-link>
        <router-view></router-view>
      </p>
    </div>
  <HelloWorld msg="Welcome to Your Vue.js App"/> -->
</template>
<script>
// import HelloWorld from &#39;./components/HelloWorld.vue&#39;
import Menu from &#39;./components/Menu.vue&#39;
export default {
  name: &#39;App&#39;,
  components: {
    // HelloWorld
    Menu
  }
}
</script>

위 코드에는 Menu.vue 컴포넌트가 있는데, 이 컴포넌트를 생성해야 하며, 내용은 추후 추가될 예정입니다

Route 정의

새로운 Routes.js를 생성하세요 src 디렉터리에 파일을 만들고 편의상 경로 목록을 작성합니다.

const routes = [
    { path: "/home", name: &#39;home&#39;, label: &#39;首页&#39;, component: () => import(&#39;./components/home.vue&#39;), },
    { path: "/about", name: &#39;about&#39;, label: &#39;关于&#39;, component: () => import(&#39;./components/about.vue&#39;), },
]
export default routes

를 사용하여 다른 구성 요소의 내용에는 변경이 없으며, router.js에서 경로를 추출하고 별도의 파일

router.js를 작성하고 경로를 소개하고 사용합니다.

import { createRouter, createWebHashHistory } from &#39;vue-router&#39;
import routes from &#39;./routes&#39;
const router = createRouter({
    history: createWebHashHistory(),
    routes: routes,
})
export default router

왼쪽 메뉴

컴포넌트 디렉토리에 새 메뉴를 생성한 다음, Element-plus의 메뉴 컴포넌트에 사이드 바를 복사하세요.

<template>
  <el-row class="tac">
    <el-col :span="24">
      <h6 class="mb-2">Default colors</h6>
      <el-menu default-active="2" class="el-menu-vertical-demo" @open="handleOpen" @close="handleClose">
        <el-sub-menu index="1">
          <template #title>
            <el-icon>
              <location />
            </el-icon>
            <span>Navigator One</span>
          </template>
          <router-link v-for="(item, index) in routes" :to="{ name: item.name }" :key="item.name">
            <el-menu-item :index="index">
              <span v-text="item.label"></span>
            </el-menu-item>
          </router-link>
        </el-sub-menu>
        <el-menu-item index="2">
          <el-icon>
            <icon-menu />
          </el-icon>
          <span>Navigator Two</span>
        </el-menu-item>
        <el-menu-item index="3" disabled>
          <el-icon>
            <document />
          </el-icon>
          <span>Navigator Three</span>
        </el-menu-item>
        <el-menu-item index="4">
          <el-icon>
            <setting />
          </el-icon>
          <span>Navigator Four</span>
        </el-menu-item>
      </el-menu>
    </el-col>
  </el-row>
</template>
<script>
import {
  Document,
  Menu as IconMenu,
  Location,
  Setting,
} from &#39;@element-plus/icons-vue&#39;
import routes from &#39;../routes&#39;
export default {
  name: &#39;Menu&#39;,
  components: { Document, IconMenu,Location, Setting },
  data() {
    return {
      routes: routes,
    }
  },
  methods: {
    handleOpen() {
      console.log("111")
    },
    handleClose() {
      console.log("222")
    },
  }
}
</script>

@element-plus/icons-vue 이 패키지를 설치해야 합니다(npm install @element-plus/icons-vue)

element-plus 공식 웹사이트의 예제는 모두 ts+setup 구문으로 작성되었습니다. 여기 js+ 반응형 구문으로 변경합니다

열 너비를 범위="24" 이상으로 변경합니다. 열 너비가 너무 작으면 글꼴 중앙에 회색 선이 표시됩니다

정의된 경로 목록을 소개합니다. Routes.js를 실행하고 콘텐츠를 라우터 링크로 루프하세요

작업 효과는 다음과 같습니다

vue3 컨테이너 레이아웃 및 탐색 라우팅을 구현하는 방법

위 내용은 vue3 컨테이너 레이아웃 및 탐색 라우팅을 구현하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
이 기사는 yisu.com에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제