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

vue3中關(guān)于路由hash與History的設(shè)置

 更新時間:2023年04月17日 09:18:07   作者:前端程序猿i  
這篇文章主要介紹了vue3中關(guān)于路由hash與History的設(shè)置方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue3路由hash與History的設(shè)置

1、history 關(guān)鍵字:createWebHistory

import { createRouter, createWebHistory } from 'vue-router'
const routes = [ {
? path: '/userinfo',
? name: 'UserInfo',
? component: () => import('../views/UserInfo.vue')
}]
const router = createRouter({
? history: createWebHistory(process.env.BASE_URL),
? routes
})
export default router

history模式直接指向history對象,它表示當(dāng)前窗口的瀏覽歷史,history對象保存了當(dāng)前窗口訪問過的所有頁面網(wǎng)址。URL中沒有#,它使用的是傳統(tǒng)的路由分發(fā)模式,即用戶在輸入一個URL時,服務(wù)器會接收這個請求,并解析這個URL,然后做出相應(yīng)的邏輯處理。

特點:

當(dāng)使用history模式時,URL就像這樣:hhh.com/user/id。相比hash模式更加好看。

雖然history模式不需要#。但是,它也有自己的缺點,就是在刷新頁面的時候,如果沒有相應(yīng)的路由或資源,就會刷出404來。

history api可以分為兩大部分,切換歷史狀態(tài) 和 修改歷史狀態(tài):

修改歷史狀態(tài):

包括了 HTML5 History Interface 中新增的 pushState() 和 replaceState() 方法,這兩個方法應(yīng)用于瀏覽器的歷史記錄棧,提供了對歷史記錄進行修改的功能。只是當(dāng)他們進行修改時,雖然修改了url,但瀏覽器不會立即向后端發(fā)送請求。如果要做到改變url但又不刷新頁面的效果,就需要前端用上這兩個API。

切換歷史狀態(tài):

包括forward()、back()、go()三個方法,對應(yīng)瀏覽器的前進,后退,跳轉(zhuǎn)操作。

配置:

想要設(shè)置成history模式,就要進行以下的配置(后端也要進行配置):

const router = new VueRouter({
? mode: 'history',
? routes: [...]
})

2、hash 關(guān)鍵字:createWebHashHistory

import { createRouter, createWebHashHistory } from 'vue-router'
const routes = [{
? path: '/userinfo',
? name: 'UserInfo',
? component: () => import('../views/UserInfo.vue')
}]
const router = createRouter({
? history: createWebHashHistory(),
? routes
})
export default router

hash模式是開發(fā)中默認(rèn)的模式,也稱作錨點,它的URL帶著一個#,例如:www.abc.com/#/vue,它的hash值就是#/vue。

特點:

hash值會出現(xiàn)在URL里面,但是不會出現(xiàn)在HTTP請求中,對后端沒有影響。所以改變hash值不會重新加載頁面。

這種模式的瀏覽器支持度很好,低版本的IE瀏覽器也支持這種模式。

hash路由被稱為是前端路由,已經(jīng)成為SPA(單頁面應(yīng)用)的標(biāo)配。

原理:

hash模式的主要原理就是onhashchange()事件:

window.onhashchange = function(event){
? ? console.log(event.oldURL, event.newURL);
? ? let hash = location.hash.slice(1);
}

 

使用onhashchange()事件的好處就是,在頁面的hash值發(fā)生變化時,無需向后端發(fā)起請求,window就可以監(jiān)聽事件的改變,并按規(guī)則加載相應(yīng)的代碼。

除此之外,hash值變化對應(yīng)的URL都會被瀏覽器記錄下來,這樣瀏覽器就能實現(xiàn)頁面的前進和后退。雖然是沒有請求后端服務(wù)器,但是頁面的hash值和對應(yīng)的URL關(guān)聯(lián)起來了。

獲取頁面hash變化的方法:

// 監(jiān)聽,當(dāng)路由發(fā)生變化的時候執(zhí)行
watch: {
? $route: {
? ? handler: function(val, oldVal){
? ? ? console.log(val);
? ? },
? ? // 深度觀察監(jiān)聽
? ? deep: true
? }
},

vue2和vue3中路由的區(qū)別和寫法

Vue 2 和 Vue 3 中路由的主要區(qū)別在于使用的路由庫不同。在 Vue 2 中,通常使用 Vue Router 作為路由庫;而在 Vue 3 中,Vue Router 仍然是官方推薦的路由庫,但也可以選擇使用新的路由庫 - Vue Router Next。

下面分別介紹在 Vue 2 和 Vue 3 中使用 Vue Router 的路由寫法:

vue3中使用 Vue Router

安裝 Vue Router:在終端中執(zhí)行以下命令進行安裝:

npm install vue-router

引入 Vue Router 并配置路由:在 main.js 中引入 Vue Router,并配置路由規(guī)則和組件對應(yīng)關(guān)系。

示例代碼如下:

import Vue from 'vue'
import VueRouter from 'vue-router'
import Home from './components/Home.vue'
import About from './components/About.vue'
?
Vue.use(VueRouter)
?
const routes = [
? { path: '/', component: Home },
? { path: '/about', component: About }
]
?
const router = newVueRouter({
? routes // 等價于 routes: routes
})
?
newVue({
? el: '#app',
? router,
? render: h =>h(App)
})

在模板中使用路由:在模板中使用 router-link 組件來實現(xiàn)路由跳轉(zhuǎn),router-view 組件用于顯示對應(yīng)的組件內(nèi)容。

示例代碼如下:

<template>
? ? <div id="app">
? ? ? ? <nav>
? ? ? ? ? ? <router-link to="/">Home</router-link>
? ? ? ? ? ? <router-link to="/about">About</router-link>
? ? ? ? </nav>
? ? ? ? <router-view></router-view>
? ? </div>
</template>

vue3中使用 Vue Router Next

安裝 Vue Router Next:在終端中執(zhí)行以下命令進行安裝:

npm install vue-router@4

引入 Vue Router Next 并配置路由:在 main.js 中引入 Vue Router Next,并配置路由規(guī)則和組件對應(yīng)關(guān)系。

示例代碼如下:

import { createApp } from 'vue'
import { createRouter, createWebHistory } from 'vue-router'
import Home from './components/Home.vue'
import About from './components/About.vue'
import App from './App.vue'
const routes = [
? { path: '/', component: Home },
? { path: '/about', component: About }
]
?
const router = createRouter({
? history: createWebHistory(),
? routes
})
?
const app = createApp(App)
app.use(router)
app.mount('#app')

在模板中使用路由:在模板中使用 router-link 組件來實現(xiàn)路由跳轉(zhuǎn),router-view 組件用于顯示對應(yīng)的組件內(nèi)容。示例代碼如下:

<template>
? ? <div id="app">
? ? ? ? <nav>
? ? ? ? ? ? <router-link to="/">Home</router-link>
? ? ? ? ? ? <router-link to="/about">About</router-link>
? ? ? ? </nav>
? ? ? ? <router-view></router-view>
? ? </div>
</template>

心得:

總體來說,在使用 Vue Router 方面,Vue 2 和 Vue 3 的寫法類似,但是在具體細(xì)節(jié)上還是有所差異。如果需要更深入地了解 Vue Router 的使用方法和技巧,建議參考官方文檔或相關(guān)教程。

總結(jié)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 詳解vue3中如何使用youtube-player

    詳解vue3中如何使用youtube-player

    這篇文章主要為大家介紹了詳解vue3中如何使用youtube-player示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue原理Compile之optimize標(biāo)記靜態(tài)節(jié)點源碼示例

    vue原理Compile之optimize標(biāo)記靜態(tài)節(jié)點源碼示例

    這篇文章主要為大家介紹了vue原理Compile之optimize標(biāo)記靜態(tài)節(jié)點源碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • element-ui中dialog彈窗關(guān)閉按鈕失效的解決

    element-ui中dialog彈窗關(guān)閉按鈕失效的解決

    這篇文章主要介紹了element-ui中dialog彈窗關(guān)閉按鈕失效的解決,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • 解決element-ui el-checkbox的一些坑

    解決element-ui el-checkbox的一些坑

    這篇文章主要介紹了解決element-ui el-checkbox的一些坑,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • Vue中的el-date-picker時間選擇器的使用實例詳解

    Vue中的el-date-picker時間選擇器的使用實例詳解

    el-date-picker是Element UI框架中提供的日期選擇器組件,它支持單個日期、日期范圍、時間、日期時間等多種選擇方式,本文給大家介紹Vue中的el-date-picker時間選擇器的使用,感興趣的朋友一起看看吧
    2023-10-10
  • Vue使用Element-UI實現(xiàn)分頁效果全過程

    Vue使用Element-UI實現(xiàn)分頁效果全過程

    element-ui官網(wǎng)上有分頁實現(xiàn)的功能,簡單方便又好用,也有很多分頁的樣式,你可以根據(jù)需要去選擇自己想要的樣式,下面這篇文章主要給大家介紹了關(guān)于Vue使用Element-UI實現(xiàn)分頁效果的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • vue實現(xiàn)GitHub的第三方授權(quán)方法示例

    vue實現(xiàn)GitHub的第三方授權(quán)方法示例

    本文主要介紹了vue實現(xiàn)GitHub的第三方授權(quán),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-11-11
  • vue.js管理后臺table組件封裝的方法

    vue.js管理后臺table組件封裝的方法

    table作為數(shù)據(jù)展示組件,在日常開發(fā)中經(jīng)常被用到,這篇文章主要給大家介紹了關(guān)于vue.js管理后臺table組件封裝的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2021-08-08
  • vue3 name 屬性的使用技巧詳解

    vue3 name 屬性的使用技巧詳解

    這篇文章主要為大家介紹了vue3 name 屬性的使用技巧詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • vue2 中使用 render 函數(shù)編寫組件的方式

    vue2 中使用 render 函數(shù)編寫組件的方式

    vue提供了聲明式編寫UI的方式,即vue提供了對DOM進行描述的方式,有兩種描述DOM的方式即模板和render 函數(shù),本文通過示例代碼介紹vue2 中使用 render 函數(shù)編寫組件的方式,感興趣的朋友跟隨小編一起看看吧
    2024-06-06

最新評論