Vue Router 之 History Mode

栏目: 编程语言 · 发布时间: 5年前

内容简介:目前我們在 Vue 的網址都會看到有macOS Mojave 10.14.5Node 12.4.0

目前我們在 Vue 的網址都會看到有 # ,因為 Vue Router 預設使用 Hash Mode,若要拿掉 # ,就要使用 History Mode。

Version

macOS Mojave 10.14.5

Node 12.4.0

Vue CLI 3.8.4

Vue 2.6.10

Vue-router 3.0.3

Add Vue Router & History Mode

Vue Router 之 History Mode

使用 Vue CLI 的 vue create 建立 vue-history

Vue Router 之 History Mode

Vue Router 雖然為官方 package,但預設並沒有包含在 Vue 內,因此需要選擇 Manually select features 另外安裝。

Vue Router 之 History Mode

除了預設的 BabelLinter / Formatter 外,使用 space bar 選擇 Router

Vue Router 之 History Mode

History ModeY

Vue Router 之 History Mode

選擇 ESLint with error prevention only

Vue Router 之 History Mode

選擇 Lint on save

Vue Router 之 History Mode

選擇 In dedicated config files ,也就是 Babel、PostCSS、ESLint … 等 工具 都有自己的 config 檔,而不會全部集中在 package.json

Vue Router 之 History Mode

Save this as a preset for future projects 選擇 n ,也就是預設不會使用 Vue Router。

Vue Router 之 History Mode

成功建立含有 Vue Router History Mode 的 project。

Vue Router 之 History Mode

package.json 可以看到 "vue-router" : "^3.0.3" ,表示 vue-router 預設已經安裝成功。

Vue Router 之 History Mode

router.js ,我們發現最大的差別多了 mode: 'history

Vue Router 預設為 hash mode,因此我們在網址要加上 # ,這是 HTML 5 所提供的功能,也就是當使用 # 時,將不會回 server 端,browser 會接管,因此會執行 Vue 的 route.js

Hash Mode 與傳統 MVC 的 route 的差別,就是你在網址要加上 # ,若你想如原本 MVC 的方式,就必須加上 mode: 'history'

$ yarn serve

Vue Router 之 History Mode

在專案目錄下輸入 yarn serve 啟動 Vue CLI 內建的 web server。

Vue Router 之 History Mode

Vue 內建 Web Server 預設啟動在 http://localhost:8080

Vue Router 之 History Mode

/about 沒出現 #

URL Rewrite

Vue Router 之 History Mode

Q : 目前看起來 History Mode 一切正常,為什麼 Vue CLI 説要提供 server setup 呢 ?

因為在網址上雖然是 /about ,但現在是 SPA,事實上只有 index.html 而已,在 web server 上並沒有 about.html ,是靠 browser 切換到 about component 而已,所以 web server 會回 404 找不到網頁。

因此必須設定當 web server 找不到網頁時,請 url rewrite 到 index.html ,改使用 Vue Router 的 history mode,由 browser 來切換 component。

若 web server 不支援 url rewrite,就只能使用 HTML 5 的 hash mode。

這也是為什麼 Vue CLI 特別警告 history mode Require proper server setup 原因,因為需要 web server 設定 url rewrite。

Conclusion

  • hash mode 不用 web server 設定 url rewrite 也能執行,但缺點是網址會有 #
  • history mode 要設定 web server 的 url rewrite,凡 404 找不到就 url rewrite 到 /index.html
  • Vue Cli 內建 web server 已經設定 url rewrite,hash mode 與 history mode 都可執行

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

经济学原理(第7版):微观经济学分册+宏观经济学分册(套装共2册)

经济学原理(第7版):微观经济学分册+宏观经济学分册(套装共2册)

曼昆 (N.Gregory Mankiw) / 梁小民、梁砾 / 北京大学出版社 / 2015-5-1 / 128

《经济学原理(第7版):微观经济学分册+宏观经济学分册》是目前国内市场上最受欢迎的引进版经济学教材之一,其最大特点是它的“学生导向”,它更多地强调经济学原理的应用和政策分析,而非经济学模型。第7版在延续该书一贯风格的同时,对第6版作了全面修订和改进。大幅更新了“新闻摘录”“案例研究”等专栏,拓展了章后习题。一起来看看 《经济学原理(第7版):微观经济学分册+宏观经济学分册(套装共2册)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

URL 编码/解码
URL 编码/解码

URL 编码/解码

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换