> 웹 프론트엔드 > View.js > Vue 라우팅을 자세히 설명하는 기사: vue-router

Vue 라우팅을 자세히 설명하는 기사: vue-router

青灯夜游
풀어 주다: 2022-09-05 11:30:30
앞으로
2014명이 탐색했습니다.

이 글은 FamilyMart의 VueVue-Router에 대해 자세히 설명하고, 라우팅 관련 지식을 배우는 것이 모든 분들께 도움이 되기를 바랍니다!

Vue 라우팅을 자세히 설명하는 기사: vue-router

프런트엔드 라우팅의 개발 역사

라우팅의 개념은 소프트웨어 공학에서 처음 등장하고 백엔드 라우팅에서 처음 구현된 이유는 웹의 개발이 주로 다음과 같은 과정을 거쳤기 때문입니다. 단계:

  • 백엔드 라우팅 단계;
  • SPA(단일 페이지 리치 애플리케이션)
초기 웹사이트 개발 전체 HTML 페이지는

서버에 의해 렌더링됩니다. 즉, 서버는 해당 HTML 페이지를 직접 생성하고 렌더링하여 클라이언트에 반환하여 표시합니다. 그림과 같이:

장점: SEO 최적화에 도움이 됨

단점: 전체 페이지는 백엔드 직원이 관리하며 HTML 코드와 데이터 해당 로직이 혼합되며 작성 및 유지 관리가 매우 까다롭습니다. 가난한. Vue 라우팅을 자세히 설명하는 기사: vue-router

2. 프론트엔드와 백엔드 분리

**프런트엔드 렌더링:**각 요청에 포함된 정적 리소스는 정적 리소스 서버에서 가져옵니다. 이러한 리소스에는 HTML+CSS+JS가 포함됩니다. 그런 다음 이러한 요청은 렌더링을 위해 프런트엔드 리소스에 반환됩니다. 클라이언트의 모든 요청은 정적 리소스 서버의 파일을 요청합니다. 현재 백엔드는 API 제공만 담당합니다.

프런트엔드와 백엔드 분리:

백엔드는 API 제공만 담당하고, 프런트엔드는 Ajax를 통해 데이터를 얻은 후 JavaScript를 통해 데이터를 페이지에 렌더링합니다.

백엔드는 end는 데이터 중심, Front-End는 상호작용과 시각화 중심

    Page(SPA) 풍부한 적용단계 :
  • Front-end와 Back의 분리를 기반으로 Front-end 라우팅 레이어 추가 -end,
프런트 엔드는 일련의 라우팅 규칙을 유지합니다

핵심: 페이지 URL을 변경하지만 페이지를 새로 고치지는 마세요.

  • vue-router 알아보기
  • Vue-Router 설치
npm install vue-router
로그인 후 복사
단계:

라우팅을 통해 매핑해야 하는 구성 요소 만들기 [관련 권장 사항:

vue 비디오 튜토리얼

]

  • createRouter를 통해 라우팅 개체를 생성하고

    경로 및 기록 모드를 전달합니다.

  • 앱을 사용하여 경로 개체 등록(사용 방법)

    경로 사용: 및
import { createRouter, createWebHashHistory } from "vue-router"

import Home from "../views/Home.vue"
import About from "../views/About.vue"
// 创建一个路由:映射关系
const router = new createRouter({
  history: createWebHashHistory(),
  routes: [
    {
      path: "/",
      redirect: "/home"
    },
    {
      path: "/home",
      component: Home
    },
    {
      path: "/about",
      component: About
    }
  ]
})

export default router
로그인 후 복사

Vue 라우팅을 자세히 설명하는 기사: vue-router보충: 경로의 기타 속성

Vue 라우팅을 자세히 설명하는 기사: vue-routername 속성: 경로의 고유 이름을 기록합니다.

meta 속성: 사용자 정의 데이터

router-link(보충)

router-link In 실제로 구성할 수 있는 속성은 많습니다:

to 속성: 문자열 또는 객체입니다. replace 속성: 바꾸기 속성이 설정된 경우 클릭하면 라우터 대신 router.replace()가 호출됩니다. 푸시(). 일반적으로 교체 속성은 사용되지 않으며 사용자 경험도 그리 좋지 않습니다.

active-class 속성: a 요소를 활성화한 후 적용되는 클래스를 설정합니다. 기본값은 router-link-active입니다.

    exact-active-class 속성: 링크가 정확하게 활성화되면 렌더링에 적용되는 클래스입니다.
  • 경로의 지연 로딩
  • 문제: 애플리케이션을 패키징하고 구축할 때 JavaScript 패키지가 매우 커져서 페이지 로딩에 영향을 미칩니다.
해결책: 서로 다른 구성 요소에 해당하는 구성 요소를 분할합니다. 경로를 다른 코드 블록으로 변환한 다음 해당 경로에 액세스할 때 해당 구성 요소가 로드됩니다. 또한 첫 번째 화면 렌더링의 효율성도 향상시킬 수 있습니다. 그 중 Vue-Router는 기본적으로 컴포넌트의 동적 로딩을 지원합니다. 컴포넌트는 컴포넌트에 전달되거나 함수를 받을 수 있으므로 함수는 Promise를 다시 넣어야 합니다.

import 함수는 Promise

Dynamic Routing

Vue 라우팅을 자세히 설명하는 기사: vue-router1을 반환합니다. 동적 라우팅

의 기본 일치는 지정된 일치 패턴의 경로를 동일한 구성 요소에 매핑합니다. 다양한 구현 및 페이지 렌더링을 달성하기 위해 다양한 요구 사항에 따라 다양한 경로를 로드할 수 있습니다.

동적 라우팅 사용은 일반적으로 역할 권한 제어와 함께 사용됩니다. 예: 모든 사용자에게 렌더링해야 하는 User 구성 요소가 있지만 사용자 ID가 다릅니다. 경로 매개변수라고 하는 경로의 동적 필드를 사용하여 이를 수행할 수 있습니다. 그런 다음 .

Vue 라우팅을 자세히 설명하는 기사: vue-router

2. 获取动态路由的值

获取动态路由的值(例如上面例子中 用户id 123),在template中,直接通过 $route.params获取值。

  • 在created中,通过 this.$route.params获取值
  • 在setup中,我们要使用 vue-router库给我们提供的一个hook useRoute

Vue 라우팅을 자세히 설명하는 기사: vue-router

3. NotFound

对于没有匹配到相应的路由,我们可以给用户匹配一个固定的页面。通过 $route.params.pathMatch获取到传入的参数

Vue 라우팅을 자세히 설명하는 기사: vue-router

路由的嵌套

组件的本身也有组件需要内部切换,这个时候就可以采用嵌套路由,在第一层路由中也使用router-view来占位之后需要渲染的组件。

Vue 라우팅을 자세히 설명하는 기사: vue-router

{
      path: "/home",
      component: () => import("../views/Home.vue"),
      children: [
        {
          path: "/show",
          component: () => import("../views/component/show.vue")
        },
        {
          path: "/detail",
          component: () => import("../views/component/detail.vue")
        }
      ]
    },
로그인 후 복사

编程式导航

1. 代码的页面跳转

通过代码来控制页面的跳转

栗子:点击一个按钮跳转页面

Vue 라우팅을 자세히 설명하는 기사: vue-router

2. query 方式的参数

通过query的方式来传递参数,在界面中通过 $route.query 来获取参数。

Vue 라우팅을 자세히 설명하는 기사: vue-router

3. 替换当前的位置

使用push的特点是压入一个新的页面,那么在用户点击返回时,上一个页面还可以回退,但是如果我们希望当前页面是一个替换 操作,那么可以使用replace。这个时候已经不能回退了。

4. 页面的前后跳转

  • router 的 go 方法(指定向前(向后)跳转几步)

  • router 的back 方法 (回溯历史,向后一步)

  • router 的forward 方法(历史中前进,向前一步)

动态添加路由

场景:根据用户的不同权限,注册不同的路由

Vue 라우팅을 자세히 설명하는 기사: vue-router

补充:路由的其他方法

删除路由有以下三种方式:

  • 方式一:添加一个name相同的路由;
  • 方式二:通过removeRoute方法,传入路由的名称;
  • 方式三:通过addRoute方法的返回值回调;

router.hasRoute():检查路由是否存在。

router.getRoutes():获取一个包含所有路由记录的数组。

路由导航守卫

vue-router 提供的导航守卫主要用来通过跳转或取消的方式守卫导航

全局的前置守卫==beforeEach==是在导航触发时会被回调的,它有两个参数:

  • to:即将进入的路由Route对象;
  • from:即将离开的路由Route对象;

返回值:

  • false:取消当前导航;
  • 不返回或者undefined:进行默认导航;
  • 返回一个路由地址:可以是一个String类型的路径也可以是一个对象

Vue 라우팅을 자세히 설명하는 기사: vue-router

1. 登录守卫功能

场景:只有登录了的用户才能看到的页面

Vue 라우팅을 자세히 설명하는 기사: vue-router

2. 其他导航守卫

Vue还提供了很多的其他守卫函数,目的都是在某一个时刻给予回调,可以更好的控制程序的流程或者功能

[导航守卫](导航守卫 | Vue Router (vuejs.org))

流程:

  • 导航被触发。

  • 在失活的组件里调用 beforeRouteLeave 守卫。

  • 调用全局的 beforeEach 守卫。

  • 在重用的组件里调用 beforeRouteUpdate 守卫(2.2+)。

  • 在路由配置里调用 beforeEnter。  解析异步路由组件。

  • 在被激活的组件里调用 beforeRouteEnter。

  • Resolve 가드(2.5+) 이전에 전역을 호출합니다.

  • 내비게이션이 확인되었습니다.

  • Each Hook 이후 전역을 호출하세요.

  • DOM 업데이트를 트리거합니다.

  • beforeRouteEnter 가드에서 next로 전달된 콜백 함수를 호출하면 생성된 컴포넌트 인스턴스가 콜백 함수의 매개변수로 전달됩니다.

더 많은 프로그래밍 관련 지식을 보려면 프로그래밍 소개를 방문하세요! !

위 내용은 Vue 라우팅을 자세히 설명하는 기사: vue-router의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

관련 라벨:
원천:csdn.net
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿