vue相关面试题:1.route和router区别;2.history和hash两种模式区别

简介: 因此在线上部署基于 history API 的单页面应用的时候,一定要后端配合支持才行,否则会出现大量的 404。以最常用的 Nginx 为例,只需要在配置的 location / 中增加下面一行即可try_files $uri /index.html;总结一下 history 模式的优缺点:优点:路径比较正规,没有井号 #缺点:兼容性不如 hash,且需要服务端支持,否则一刷新页面就404了

文章目录

vue中route和router有什么区别?

vue路由中,history和hash两种模式有什么区别?

vue中route和router有什么区别?

this.$ router

this.$ router是 router 实例

通过 this.$ router 访问路由器,相当于获取了整个路由文件,在$router.option.routes中,或查看到当前项目的整个路由结构 具有实例方法


// 导航守卫

router.beforeEach((to, from, next) => {

 /* 必须调用 `next` */

})

router.beforeResolve((to, from, next) => {

 /* 必须调用 `next` */

})

router.afterEach((to, from) => {})


// 动态导航到新路由

router.push

router.replace

router.go

router.back

router.forward

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

this.$ route

当前激活的路由信息对象。这个属性是只读的,里面的属性是 immutable (不可变) 的,不过可以 watch (监测变化) 它。

通过 this.$route 访问的是当前路由,获取和当前路由有关的信息


fullPath: ""  // 当前路由完整路径,包含查询参数和 hash 的完整路径

hash: "" // 当前路由的 hash 值 (锚点)

matched: [] // 包含当前路由的所有嵌套路径片段的路由记录

meta: {} // 路由文件中自赋值的meta信息

name: "" // 路由名称

params: {}  // 一个 key/value 对象,包含了动态片段和全匹配片段就是一个空对象。

path: ""  // 字符串,对应当前路由的路径

query: {}  // 一个 key/value 对象,表示 URL 查询参数。跟随在路径后用'?'带的参数

1

2

3

4

5

6

7

8

vue路由中,history和hash两种模式有什么区别?

hash 模式

hash 模式是一种把前端路由的路径用井号 # 拼接在真实 URL 后面的模式。当井号 # 后面的路径发生变化时,浏览器并不会重新发起请求,而是会触发 hashchange 事件。


示例:


<a href="#/a">A页面</a>

<a href="#/b">B页面</a>

<div id="app"></div>

<script>

 function render() {

   app.innerHTML = window.location.hash

 }

 window.addEventListener('hashchange', render)

 render()

</script>

1

2

3

4

5

6

7

8

9

10

在上面的例子中,我们利用 a 标签设置了两个路由导航,把 app 当做视图渲染容器,当切换路由的时候触发视图容器的更新,这其实就是大多数前端框架哈希路由的实现原理。


总结一下 hash 模式的优缺点:

优点:浏览器兼容性较好,连 IE8 都支持

缺点:路径在井号 # 的后面,比较丑


history 模式

history API 是 H5 提供的新特性,允许开发者直接更改前端路由,即更新浏览器 URL 地址而不重新发起请求。

示例:


a href="javascript:toA();">A页面</a>

<a href="javascript:toB();">B页面</a>

<div id="app"></div>

<script>

 function render() {

   app.innerHTML = window.location.pathname

 }

 function toA() {

   history.pushState({}, null, '/a')

   render()

 }

 function toB() {

   history.pushState({}, null, '/b')

   render()

 }

 window.addEventListener('popstate', render)

</script>


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

浏览器在刷新的时候,会按照路径发送真实的资源请求,如果这个路径是前端通过 history API 设置的 URL,那么在服务端往往不存在这个资源,于是就返回 404 了。上面的参数的意思就是如果后端资源不存在就返回 history.html 的内容。


因此在线上部署基于 history API 的单页面应用的时候,一定要后端配合支持才行,否则会出现大量的 404。以最常用的 Nginx 为例,只需要在配置的 location / 中增加下面一行即可

try_files $uri /index.html;


总结一下 history 模式的优缺点:

优点:路径比较正规,没有井号 #

缺点:兼容性不如 hash,且需要服务端支持,否则一刷新页面就404了


目录
相关文章
|
16天前
|
JavaScript 前端开发 网络架构
vue 路由器history和hash工作模式
vue 路由器history和hash工作模式
|
10天前
|
JavaScript 数据可视化
vue-cli学习二:vue-cli3版本 创建vue项目后,Runtime-Compiler和Runtime-only两个模式详解;vue项目管理器;配置文件的配置在哪,以及如何配置
这篇文章详细介绍了Vue CLI 3版本创建项目时的Runtime-Compiler和Runtime-only两种模式的区别、Vue程序的运行过程、render函数的使用、eslint的关闭方法,以及Vue CLI 2和3版本配置文件的不同和脚手架3版本创建项目的配置文件配置方法。
23 3
vue-cli学习二:vue-cli3版本 创建vue项目后,Runtime-Compiler和Runtime-only两个模式详解;vue项目管理器;配置文件的配置在哪,以及如何配置
|
1月前
|
缓存 JavaScript 前端开发
vue面试题
vue面试题
155 64
|
2天前
|
JavaScript
vue面试
vue面试
8 3
|
18天前
|
JavaScript 前端开发
vue尚品汇商城项目-day01【8.路由跳转与传参相关面试题】
vue尚品汇商城项目-day01【8.路由跳转与传参相关面试题】
28 0
vue尚品汇商城项目-day01【8.路由跳转与传参相关面试题】
|
2月前
|
JavaScript 前端开发 编译器
【Vue面试题三十二】、vue3有了解过吗?能说说跟vue2的区别吗?
这篇文章介绍了Vue 3相对于Vue 2的改进和新增特性,包括性能提升、体积减小、更易维护、更好的TypeScript支持、新的Composition API、新增的Teleport和createRenderer功能,以及Vue 3中的非兼容性变更和API的移除或重命名。
【Vue面试题三十二】、vue3有了解过吗?能说说跟vue2的区别吗?
|
2月前
|
JavaScript 前端开发 API
【Vue面试题三十一】、你是怎么处理vue项目中的错误的?
这篇文章讨论了Vue项目中错误的处理方式,包括后端接口错误和代码逻辑错误的处理策略。文章详细介绍了如何使用axios的拦截器处理后端接口错误,以及Vue提供的全局错误处理函数`errorHandler`和生命周期钩子`errorCaptured`来处理代码中的逻辑错误。此外,还分析了Vue错误处理的源码,解释了`handleError`、`globalHandleError`、`invokeWithErrorHandling`和`logError`函数的作用和处理流程。
【Vue面试题三十一】、你是怎么处理vue项目中的错误的?
|
2月前
|
资源调度 JavaScript 前端开发
Vue Router 的使用方式是什么
【8月更文挑战第30天】Vue Router 的使用方式是什么
18 2
|
2月前
|
设计模式 JavaScript 前端开发
Vue.js组件设计模式:构建可复用组件库
在Vue.js中,构建可复用组件库是提升代码质量和维护性的核心策略。采用单文件组件(SFC),定义props及默认值,利用自定义事件和插槽进行灵活通信,结合Vuex或Pinia的状态管理,以及高阶组件技术,可以增强组件的功能性和灵活性。通过合理的抽象封装、考虑组件的可配置性和扩展性,并辅以详尽的文档和充分的测试,能够打造出既高效又可靠的组件库。此外,采用懒加载、按需导入技术优化性能,制定设计系统和风格指南确保一致性,配合版本控制、CI/CD流程和代码审查机制,最终形成一个高品质、易维护且具有良好社区支持的组件库。
60 7
|
2月前
|
设计模式 JavaScript 前端开发
Vue.js 组件设计模式:在前端热潮中找到归属感,打造可复用组件库,开启高效开发之旅!
【8月更文挑战第22天】Vue.js 以其高效构建单页应用著称,更可通过精良的组件设计打造可复用组件库。组件应职责单一、边界清晰,如一个显示文本并触发事件的按钮组件,通过 props 传递标签文本,利用插槽增强灵活性,允许父组件注入动态内容。结合 CSS 预处理器管理和封装独立模块,配以详尽文档,有效提升开发效率及代码可维护性。合理设计模式下,组件库既灵活又强大,持续实践可优化项目工作流。
47 1