vue3不能使用history.pushState修改url參數(shù)踩坑
前言
在重構我的 vue-use-sync-url(輔助將數(shù)據(jù)和 url 參數(shù)進行同步的工具庫)時,遇到了一個使用 window.history.pushState 來修改地址欄的 url 參數(shù)的 bug,準確來說是 vue-router 的 bug,下面就來講講具體是怎么回事。
問題
場景如下,有一個輸入框里面輸入了內容,點擊搜索按鈕使用 window.history.pushState 將數(shù)據(jù)同步到 url 參數(shù)上。然后再點擊 go about 按鈕跳轉到別的頁面,關鍵的來了,這時候你點擊瀏覽器左上角的回退按鈕回到剛才的頁面,url 上的 keywords 參數(shù)變沒了! 這里上個測試鏈接 codesandbox
<script setup>
import { ref } from "vue";
const keywords = ref("123")
const handleClick = () => {
window.history.pushState({}, "", `${window.location.pathname}?keywords=${keywords.value}`)
}
</script>
<template>
<input v-model="keywords" />
<button @click="handleClick">搜索</button>
<router-link to="/about">go about</router-link>
</template>
追根溯源
一開始想是不是我寫的有問題?測試了 vue2-router 和 react-router 都沒有這個問題,所以我就將問題鎖定在了 vue3-router 了。因為 router-link 和直接執(zhí)行了 router.push 操作是一樣的,所以我就去找 push 操作所在的源碼位置,最終在 packages/router/src/history/html5.ts 中找到了如下代碼。

可以看到在這個 push 函數(shù)中,在第 288 行,執(zhí)行了一次 replace 的操作,而在第 297 行才是真正的 push 操作。我將第 288 行注釋之后,上面的 demo 就跑通了,但是直覺告訴我它這里這么做是有原因的,但是想弄明白估計得將整個庫的源碼看完,沒有這個精力。直接提了個 issue,在它的 github issue 中我發(fā)現(xiàn)了好幾個由于這個第 288 行代碼產(chǎn)生的問題,例如 #1416、#1526、#1529。維護者在我的 issue 中是這么回答的。

結合他在其它 issue 中的回答,大概是如下這么個意思。直接使用 history api,路由器是不知道的,應該避免使用,最好使用 router.push 來進行更改。還說到第 288 行對于更新當前歷史記錄條目是必要的,以便能夠通過導航守衛(wèi)取消ui 發(fā)起的導航。它允許知道導航的方向和在歷史堆棧中的相對位置。不幸的是,目前還沒有其他方法可以做到這一點。
我補充道,在 vue2 和 react 中沒有這個問題,你不覺得這是個 bug 嗎?他說在 vue2 中使用 hisotry api 可能會產(chǎn)生你沒有遇到過的問題,vue-router 在 vue3 中比 vue2 擁有更多的功能等等。
解決
沒辦法,維護者不覺得這是個 bug,最后只能妥協(xié)使用 router.push 來解決,并將 vue-router 的依賴添加到 peerDependencies 中。在一些場景下,如果想封裝一個庫在各個框架中共同使用就不行了,在這里必須使用 router.push 才可以,我覺得還是不太好的。
以上就是vue3不能使用history.pushState修改url參數(shù)踩坑的詳細內容,更多關于vue3修改url參數(shù)踩坑的資料請關注腳本之家其它相關文章!
相關文章
前端使用print.js實現(xiàn)打印功能(基于vue)
最近新接了一個需求,想要在前端實現(xiàn)打印功能,下面這篇文章主要給大家介紹了關于前端使用print.js實現(xiàn)打印功能(基于vue)的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下2023-05-05
Vue+echart?展示后端獲取的數(shù)據(jù)實現(xiàn)
本文主要介紹了Vue+echart?展示后端獲取的數(shù)據(jù),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2023-01-01
使用Vue與WebSocket創(chuàng)建實時通知系統(tǒng)
在現(xiàn)代應用開發(fā)中,實時性已成為用戶體驗的一個重要組成部分,ue 作為一款流行的前端框架,配合 WebSocket,可以輕松構建實時通知系統(tǒng),在本文中,我們將通過一個簡單的示例,使用 Vue 3 的 Composition API(setup 語法糖)來創(chuàng)建一個實時通知系統(tǒng)2024-11-11
vue 對axios get pust put delete封裝的實例代碼
在本篇文章里我們給各位整理的是一篇關于vue 對axios get pust put delete封裝的實例代碼內容,有需要的朋友們可以參考下。2020-01-01

