本篇文章主要介紹了vue-router路由參數刷新消失的問題解決方法,具有一定的參考價值,有興趣的小夥伴們可以參考一下
場景: vue-router實作的單頁應用,登入頁呼叫登入介面後,伺服器傳回使用者訊息,然後透過router.push({name: 'index', params: res.data})傳給首頁組件,並在主頁顯示資料。但是刷新頁面後,資料就消失了。
解決方案:
1、session&伺服器渲染
傳統的方案是,登入頁和主頁是單獨的兩個頁面,登入成功後伺服器產生使用者資訊對應的session,然後渲染主頁數據,並透過回應頭將sessionid傳給瀏覽器並產生相應的 cookie檔案。這樣下次請求頁面時,瀏覽器會在http header帶上對應的cookie,然後伺服器根據cookie中的sessionid判斷使用者是否登錄,再顯示使用者資料。
如果專案採用前後端分離思想,伺服器只提供接口,不進行伺服器渲染,那麼這種辦法是行不通了。
2、$route.query
#我們可以在路由跳轉的時候帶上登入請求的參數:
router.push({name:'index', query:{username: 'xxx', password: 'xxxxxx'}}) ... this.$ajax({ url: 'xxx', method: 'post', data: { username: this.$route.query.username, password: this.$route.query.password } })
這樣登入參數會被保存在url中,像這樣:“http://xxx.xxx.xxx/index?username=xxx&password=xxxxxx”,然後在created鉤子中呼叫登入介面來傳回資料。
即使密碼進行了md5加密,將使用者名稱密碼這類敏感資訊放在url中肯定也是不合理。
3、cookie
另一個辦法是把登入參數存入cookie,然後在created鉤子中取得cookie中存的信息,再調用登入介面。將使用者名稱密碼存入cookie中同樣不合理,改進版是登入成功後伺服器回傳一個token,在有效期限內透過token取得使用者資料。
cookie存取資料比較麻煩,因為cookie中鍵值對是字串並以 "=" 鏈接,需要額外寫入操作cookie的方法。
<script> function setCookie (name, value, exdays) { let date = new Date() date.setTime(date.getTime() + (exdays * 24 * 60 * 60 * 1000)) let expires = "expires=" + date.toGMTString() document.cookie = name + "=" + value + "; " + expires } function getCookie (name) { name = name + "=" let cookieArr = document.cookie.split(';') for (let i = 0; i < cookieArr.length; i++) { let cookie = cookieArr[i].trim() if (cookie.indexOf(name) === 0) { return cookie.slice(name.length) } } return "" }
4、HTML5 Web存儲
#提到Web存儲,潛意識肯定覺得很多瀏覽器都不支持,其實IE8以上都支援localStorage和sessionStorage了。 Vue專案最低支援IE9,所以可以放心的使用Web儲存。
localStorage儲存資料沒有時間限制,不主動刪除就不會失效。而sessionStorage是在頁面或瀏覽器關閉時就會失效,適合本場景應用。
我們可以把token資訊存在sessionStorage中,然後每次刷新頁面透過token請求資料;但是既然能夠把token儲存到本地,為什麼不直接把常用的資料直接儲存到本地呢?利用本地數據,可以減少客戶端網路請求,還可以降低伺服器負擔。
由於localStorage和sessionStorage是唯讀的,不能直接將其指向一個物件。也不能利用Object.assign()複製對象,因為值會變成字串"[object Object]",所有隻有透過循環為 sessionStorage 新增屬性了。
... for (var key in res.data.customer) { sessionStorage[key] = res.data.customer[key] } ...
以上是我最近工作遇到的問題,最後採用的方案是使用sessionStorage儲存資料。
以上是vue-router路由參數刷新消失的問題解決方法詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

JavaScript在現實世界中的應用包括服務器端編程、移動應用開發和物聯網控制:1.通過Node.js實現服務器端編程,適用於高並發請求處理。 2.通過ReactNative進行移動應用開發,支持跨平台部署。 3.通過Johnny-Five庫用於物聯網設備控制,適用於硬件交互。

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

MinGW - Minimalist GNU for Windows
這個專案正在遷移到osdn.net/projects/mingw的過程中,你可以繼續在那裡關注我們。 MinGW:GNU編譯器集合(GCC)的本機Windows移植版本,可自由分發的導入函式庫和用於建置本機Windows應用程式的頭檔;包括對MSVC執行時間的擴展,以支援C99功能。 MinGW的所有軟體都可以在64位元Windows平台上運作。

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

記事本++7.3.1
好用且免費的程式碼編輯器

Dreamweaver Mac版
視覺化網頁開發工具

SublimeText3 Linux新版
SublimeText3 Linux最新版