在 GitHub Pages 中使用 Vue Router
本文主要是由于这个倒计时项目以路径参数的形式接收自定义日期,出于美观的原因我不想用 hash router,而是使用 history router 。如果用 hash router 就不会有这个问题了。此文终结
GitHub Pages 只能帮你生成一个静态网站,但它支持用 404.html 作为一个 fallback(原谅我不知道怎么用中文描述比较贴切)利用这个机制,和 sessionStorage 或者 localStorage 就可以实现我们的目的。
404.html
可以把它放到项目中的 /public 目录,或者放到你为 GitHub Pages 准备的分支里面,我个人选择 /public,方便管理。
1 |
|
如果你的 GitHub Pages 没有用自定义域名,就是说它的链接是 https://foo.github.io/bar,就要把代码里的 / 替换成 /bar。至于具体是用 localStorage 还是 sessionStorage 这个随你了。
App.vue
这里只贴出来代码部分,模板不再展示,如下:
1 | import { onBeforeMount } from 'vue' |
这里我只是从逻辑上认为,应该是挂载前先加载到正确的路径,所以使用了 onBeforeMount 而不是 onMounted,具体选哪个看你了。
如果不想用 vueuse 那就直接操作 sessionStorage 或者 localStorage 对象,不再赘述。
总结
在 404.html 里保存了当前的路径,通过 sessionStorage 或者 localStorage 传给 Vue,之后在 Vue 中判断,如果存在就加载到这个路径,从而达到使用 history router 的目的。
本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 喵喵小窝!