Vue Router 是一个官方的 Vue.js 路由管理器,它可以将组件与标识符映射为路由,然后将其传递给 Vue.js 实例进行渲染,在 Vue Router 中主要有两种路由模式:hash 模式和 history 模式。
Vue Router 是一个官方的 Vue.js 路由管理器,它可以将组件与标识符映射为路由,然后将其传递给 Vue.js 实例进行渲染,在 Vue Router 中主要有两种路由模式:hash 模式和 history 模式。
hash 模式
hash 模式就是将路由信息放在 url 中的 hash (#)中,这种模式下的 url 格式为:
http://localhost:8080/#/home
在 Vue Router 中使用 hash 模式的代码如下:
const router = new VueRouter({
mode: 'hash',
routes: [
{
path: '/home',
name: 'home',
component: Home
}
]
})
使用 hash 模式时,路由的变化不会导致浏览器向服务器发送请求,因为 hash 符号后面的内容是由浏览器自行解析的。并且 hash 模式下还可以根据 hashchange 事件进行路由的监听和切换。
history 模式
history 模式是使用 HTML5 的 history API 来实现 URI 与页面内容的映射关系,使用这种方式时,url 格式为:
http://localhost:8080/home
在 Vue Router 中使用 history 模式的代码如下:
const router = new VueRouter({
mode: 'history',
routes: [
{
path: '/home',
name: 'home',
component: Home
}
]
})
相较于 hash 模式,history 模式更加简洁美观,但是要在服务器中进行相应的配置,否则在正常访问中会出现 404 错误,同时支持 history 模式的浏览器也有限。
示例:
在 hash 模式下,当我们从 /home
跳转到 /about
时,url 格式为:http://localhost:8080/#/about
;而在 history 模式下,url 格式为:http://localhost:8080/about
。
// hash 模式下的代码示例
const router = new VueRouter({
mode: 'hash',
routes: [
{
path: '/home',
name: 'home',
component: Home
},
{
path: '/about',
name: 'about',
component: About
}
]
})
// history 模式下的代码示例
const router = new VueRouter({
mode: 'history',
routes: [
{
path: '/home',
name: 'home',
component: Home
},
{
path: '/about',
name: 'about',
component: About
}
]
})
总而言之,Vue Router 中的两种路由模式各有优缺点,我们可以根据具体业务场景来选择。
本文标题为:vue-router的两种模式的区别
- webpack的懒加载和预加载详解 2023-08-11
- 一款css实现的鼠标经过按钮的特效 2024-01-06
- Vue的一些问题的整理 2023-10-08
- jQuery实现带滚动导航效果的全屏滚动相册实例 2024-02-21
- javascript中indexOf技术详解 2023-12-24
- Ajax上传图片及上传前先预览功能实例代码 2023-02-14
- Vue框架基础——迈出第一步 2023-10-08
- window.location.hash 使用说明 2024-01-17
- JS+CSS实现弹出全屏灰黑色透明遮罩效果的方法 2024-02-24
- CSS双飞翼布局的两种方式实现示例 2023-12-13