>웹 프론트엔드 >프런트엔드 Q&A >vue-router의 두 가지 모드의 차이점은 무엇입니까?

vue-router의 두 가지 모드의 차이점은 무엇입니까?

青灯夜游
青灯夜游원래의
2022-03-03 16:39:455981검색

차이점: 1. 기록 URL에는 "#" 기호가 없지만 해시에는 있습니다. 3. 기록에 의해 수정된 URL은 동일한 도메인의 모든 URL일 수 있으며 해시는 동일한 문서의 URL입니다. ; 3. 동일한 URL에 대해 기록이 트리거됩니다. 브라우저 기록 스택에 추가되면 해시가 트리거되지 않습니다.

vue-router의 두 가지 모드의 차이점은 무엇입니까?

이 튜토리얼의 운영 환경: Windows 7 시스템, vue 버전 2.9.6, DELL G3 컴퓨터.

vue-router 두 가지 모드

1.hash 모드

vue-router의 기본값은 해시'[hæʃ]' 모드입니다. 이 모드는 URL의 해시를 사용하여 전체 URL을 시뮬레이션합니다. URL이 변경되면 단일 페이지 애플리케이션인 페이지가 다시 로드되지 않습니다. # 뒤의 해시가 변경되면 브라우저가 서버에 요청을 보내지 않습니다. 브라우저가 요청을 보내지 않으면 페이지가 새로 고쳐지지 않고 hasChange 이벤트가 트리거되어 페이지의 일부를 업데이트합니다. 해시값의 변화를 모니터링하여 콘텐츠를 운영합니다.

해시 모드의 경우 hashHistory 객체가 생성됩니다. 다른 경로에 액세스하면 두 가지 일이 발생합니다.

HashHistory.push()는 브라우저가 방문한 기록 스택의 맨 위에 새 경로를 추가하고 HasHistory.replace는 () 경로를 현재 스택의 맨 위로 바꿉니다.

vue-router의 두 가지 모드의 차이점은 무엇입니까?

2.history 모드

HTML5 표준 출시로 인해 pushState() 및 replacementState()라는 두 가지 API가 더 있습니다. 이 두 API

(1)를 통해 요청을 보내지 않고도 URL 주소를 변경할 수 있습니다.

(2) 기록 스택을 읽을 수 있을 뿐만 아니라 브라우저 기록 스택을 수정할 수도 있습니다.

또한 popState()가 있습니다. 브라우저가 새로운 상태로 점프하면 popState 이벤트가 트리거됩니다.

기록 상태 추가/수정

에는 pushStatereplaceState라는 두 가지 메서드가 포함되어 있습니다. 이 두 가지 메서드는 stateObj, title, urlpushState,replaceState两个方法,这两个方法接收三个参数:stateObj,title,url

// 逐条添加历史记录条目
window.history.pushState(stateObject, title, URL)
// 修改历史记录
window.history.replaceState(stateObject, title, URL)

切换历史记录

包括 backforwardgorrreee

전환이라는 세 가지 매개변수를 받습니다. History앞으로(forward) 및 뒤로(back) 탐색에 해당하는 back, forwardgo의 세 가지 메서드가 포함되어 있습니다. , 점프(이동) 조작.

  • 차이:

  • 히스토리와 해시 모두 브라우저의 두 가지 기능을 사용하여 프런트 엔드 라우팅을 구현합니다. 히스토리는 검색 기록 스택의 API를 사용하여 구현되고 해시는 해시 값을 모니터링하여 구현됩니다.
  • 기록의 URL에는 '#' 기호가 없으며 해시는 반대입니다. 기록에 의해 수정된 URL은 동일한 도메인의 모든 URL이 될 수 있으며 해시는 동일한 문서의 URL 동일한 URL에 대해 기록이 추가됩니다. 브라우저 기록 스택에 해싱이 실행되지 않습니다.
  • 히스토리와 해시의 장단점


히스토리가 해시보다 아름답다. , 해시만 동일한 문서의 URL일 수 있습니다
  • 역사 모드에서는 백엔드 지원이 필요한 경우가 많습니다. 백엔드 nginx가 라우팅 주소를 포함하지 않으면 404를 반환합니다. 해시는 동일한 문서의 URL이므로 , 백엔드가 라우팅 주소를 포함하지 않더라도 404
  • 를 반환하지 않습니다. 해시 모드에서 URL이 백엔드에 매개변수로 전달되면 백엔드는 '#' 기호에서 직접 잘리고 '#' 기호 앞의 URL만 처리하므로 # 뒤에 매개변수 내용이 남게 됩니다. 손실의 문제가 있지만 해시 모드에서는 이 문제에 대한 해결책도 있습니다.
  • 기록 모드에서 무엇이 두려운가요?
  • 은 앞으로 또는 뒤로 가는 것을 두려워하지 않지만 새로 고침은 실제로 서버를 요청하기 때문에
  • refresh
(백엔드가 준비되지 않은 경우)를 두려워합니다.

히스토리 모드에서는 경로를 자유롭게 수정

할 수 있습니다. 히스토리 모드의 최종 경로는 URL의 경로명에 반영됩니다. 이 부분은 서버로 전송되므로 서버는 이에 따라 가능한 각 경로 값을 매핑해야 합니다.

새로 고침 시 서버에 해당 응답이나 리소스가 없으면 1분마다 404가 표시됩니다.

(학습 영상 공유:

vuejs 튜토리얼, 웹 프론트엔드

)

위 내용은 vue-router의 두 가지 모드의 차이점은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.