欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue3中createWebHistory和createWebHashHistory的區(qū)別詳析

 更新時間:2023年06月01日 11:31:05   作者:weixin_44917334  
這篇文章主要給大家介紹了關于Vue3中createWebHistory和createWebHashHistory區(qū)別的相關資料,文中通過實例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

前言

Vue3 是目前比較流行的前端框架之一,它提供了很多方便的 API 來幫助我們開發(fā)高效、可維護的應用程序。在使用 Vue Router 進行路由管理時,我們可以使用 createWebHistory 和 createWebHashHistory 來創(chuàng)建不同類型的路由模式。本文將介紹這兩種模式的區(qū)別和如何選擇合適的模式。

createWebHistory

createWebHistory 是 Vue Router 提供的一種基于瀏覽器 history API 的路由模式,它使用了 HTML5 中的 history.pushState 和 history.replaceState 方法來實現(xiàn)路由跳轉。這種模式可以使得 URL 更加直觀,而且不會在 URL 中添加任何特殊字符。例如,我們可以將路由設置為 /home、/about 等等。

使用 createWebHistory 可以通過以下方式創(chuàng)建一個路由:

import { createRouter, createWebHistory } from 'vue-router'
import Home from '@/views/Home.vue'
import About from '@/views/About.vue'

const router = createRouter({
  history: createWebHistory(),
  routes: [
    {
      path: '/home',
      name: 'home',
      component: Home
    },
    {
      path: '/about',
      name: 'about',
      component: About
    }
  ]
})

在使用 createWebHistory 時,需要注意以下幾點:

在使用 createWebHistory 時,需要在服務器端進行一些配置。因為使用了 history API,如果直接在瀏覽器中刷新或直接訪問某個路由,服務器將無法識別該路由,并返回 404 錯誤。因此,需要在服務器端配置,將所有的路由請求都返回首頁,再由前端代碼進行路由的匹配和處理。

createWebHistory 只支持 HTML5 標準瀏覽器,對于老版本的瀏覽器無法使用。

在開發(fā)環(huán)境下,我們需要將 webpack 的 historyApiFallback 屬性設置為 true,以便在開發(fā)環(huán)境下正常使用路由。

createWebHashHistory

createWebHashHistory 是 Vue Router 提供的一種基于瀏覽器 URL 的 hash 路由模式,它將路由添加到 URL 中的 hash 中,例如:/#/home、/#/about。這種模式可以避免服務器配置的問題,而且支持所有瀏覽器。但是,由于 URL 中添加了 hash,因此在搜索引擎的 SEO 優(yōu)化中存在一些問題。

使用 createWebHashHistory 可以通過以下方式創(chuàng)建一個路由:

import { createRouter, createWebHashHistory } from 'vue-router'
import Home from '@/views/Home.vue'
import About from '@/views/About.vue'
const router = createRouter({
  history: createWebHashHistory(),
  routes: [
    {
      path: '/home',
      name: 'home',
      component: Home
    },

補充:Vue使用createWebHistory 頁面刷新變成白頁 解決

Vue使用createWebHistory 頁面刷新變成白頁 解決辦法

hash模式時,項目的根目錄是不變的,而在history模式時,以/開頭的嵌套路徑會被當做根據(jù)經。

所以更改文件webpack.prod.config.js(publicPath從’./‘更改為’/’)即可解決此問題

總結

到此這篇關于Vue3中createWebHistory和createWebHashHistory區(qū)別詳析的文章就介紹到這了,更多相關createWebHistory和createWebHashHistory區(qū)別內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 如何去掉ElementUI Table的hover變色問題

    如何去掉ElementUI Table的hover變色問題

    這篇文章主要介紹了如何去掉ElementUI Table的hover變色問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-09-09
  • vue框架編輯接口頁面下拉級聯(lián)選擇并綁定接口所屬模塊

    vue框架編輯接口頁面下拉級聯(lián)選擇并綁定接口所屬模塊

    這篇文章主要為大家介紹了vue框架編輯接口頁面實現(xiàn)下拉級聯(lián)選擇以及綁定接口所屬模塊,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-05-05
  • 利用Vue3和element-plus實現(xiàn)圖片上傳組件

    利用Vue3和element-plus實現(xiàn)圖片上傳組件

    element-plus提供了uploader組件,但是不好定制化。所以本文將利用Vue3和element-plus實現(xiàn)一個圖片上傳的組件,感興趣的可以了解一下
    2022-03-03
  • Vue中的變量賦值問題

    Vue中的變量賦值問題

    這篇文章主要介紹了Vue中的變量賦值問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • vue+iview 實現(xiàn)可編輯表格的示例代碼

    vue+iview 實現(xiàn)可編輯表格的示例代碼

    這篇文章主要介紹了vue+iview 實現(xiàn)可編輯表格的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-10-10
  • vue.extend實現(xiàn)alert模態(tài)框彈窗組件

    vue.extend實現(xiàn)alert模態(tài)框彈窗組件

    這篇文章主要為大家詳細介紹了vue.extend實現(xiàn)alert模態(tài)框彈窗組件,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-04-04
  • Vue的三種路由模式總結

    Vue的三種路由模式總結

    這篇文章主要介紹了Vue的三種路由模式總結,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • uniapp嵌套webview無法返回上一級解決方式

    uniapp嵌套webview無法返回上一級解決方式

    uniapp是一款非常強大的跨平臺開發(fā)框架,它可以讓我們只編寫一份代碼,就能在多個平臺上運行,這篇文章主要給大家介紹了關于uniapp嵌套webview無法返回上一級的解決方式,需要的朋友可以參考下
    2024-05-05
  • vue-tree-chart樹形組件的實現(xiàn)(含鼠標右擊事件)

    vue-tree-chart樹形組件的實現(xiàn)(含鼠標右擊事件)

    Vue-Tree-Chart,一個Vue.js2組件,本文就詳細的介紹一下vue-tree-chart樹形組件的實現(xiàn)(含鼠標右擊事件),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • Vue項目分環(huán)境打包的實現(xiàn)步驟

    Vue項目分環(huán)境打包的實現(xiàn)步驟

    這篇文章主要介紹了Vue項目如何分環(huán)境打包,實現(xiàn)方法大概分為六步驟,需要的朋友可以參考下
    2018-04-04

最新評論