• 【面试题】如何去掉vue的url地址中的#号?及其原理?


    如何去掉vue的url地址中的#号?及其原理?

    点击打开视频讲解更加详细

    如何去掉vue的url地址中的#号?

    import Vue from 'vue';
    
    import VueRouter from 'vue-router';
    
    Vue.use(VueRouter)
    
    // 1. 定义一些路由
    // 每个路由都需要映射到一个组件。
    const routes = [
        { path: '/home', component: ()=> import('../views//home.vue') },
        { path: '/about', component: ()=> import('../views/about.vue') },
    ]
    
    const router = new VueRouter({
        mode: 'hash',       //默认是hash模式,url是带#号的
        // mode: 'history',     //history模式url不带#号
        routes
      })
      
    export default router
    

    hash模式实现原理

    hash模式主要是根据url的hash值来跳转不同的路由页面。
    采用hash模式的路由模式中,url后面有一个#,#后面包括#就是此路由的hash值,hash模式背后的原理是onhashchange事件,可以在window对象上监听这个事件
    vue中hash模式的原理就是通过监听hash值的变化来匹配不同的组件,进而来重新渲染视图。

    优点

    • 兼容性强,兼容性达到了IE8
    • 除发送ajax和资源请求外不会发送其他多余请求
    • 改变#后的路径、不会自动刷新页面
    • 无需服务端进行配合

    缺点

    • 访问路径上包含#,不美观
    • 对于需要锚点功能的需求会与当前路由机制发生冲突
    • 重定向操作时,后段无法获取url完整路径。

    监听onhashchange事件案例:

    src\views\home.vue

    
    
    
    
    

    src\views\about.vue

    
    
    
    
    
    

    history模式实现原理

    优点

    • 符合url地址规范, 不需要#, 使用起来比较美观
    • 可以使用history.state获取完整的路由信息
    • 后端可以获取到完整的路由信息

    缺点

    • 兼容性只到IE10
    • 改变url路径后、会重新请求资源。
    • 若访问的路由地址不存在时、会报404,需服务端配合支持重定向返回统一的404页面。

    history路由中我们使用onpopstate事件函数来监听history路由的变化,但是popstate事件函数只能监听到history.go、forward、back的切换路由方式,但是它不能够监听到pushState添加历史记录(就是在页面中点击某个a标签进行跳转的方式,点击页面顺序:a->b->c,记录的历史记录中a、b、c都存在,而replaceState则不同)、replaceState(点击页面顺序:a->b->c,记录的历史记录中只有a->c,即用c代替了b记录,b记录被删除了)切换路由的方式。

    监听popstate、pushState、replaceState事件案例:

    src\views\home.vue

    
    
    
    
    

    src\views\about.vue

    
    
    
    
    
    

    hash和history的区别

    hash模式的url后跟hash值#…,它的原理就是使用window.onHashChange来监听hash值的改变,一旦发生变化就找出此hash值所匹配的组件,进而将组件渲染到页面中。但是hash模式这种带hash值的url是非常丑的,项目中也很少用hash模式。

    history模式中的url是以/user这种格式,比较常见,它的原理是通过window.onpopstate来监听路由变化,进而匹配不同的组件来渲染出来。

    若对您有帮助,请点击跳转到B站一键三连哦!感谢支持!!!

  • 相关阅读:
    卷起来!阿里高工携 18 位高级架构师耗时 57 天整合的 1658 页面试总结
    数据链路层和DNS之间的那些事~
    Win10卸载KB5014699补丁教程
    流水的数字内容,铁打的内容风控
    在写windows C++代码的时候,从代码安全角度考虑,我们应该注意什么?
    力扣第37题 解数独 c++ 难~ 回溯
    关于F大学教学主体偏离的核心矛盾分析
    php学习总结
    Linuxd的内核定时器 timer_list
    蓝桥杯 第 3 场算法双周赛4,7题
  • 原文地址:https://www.cnblogs.com/mochenxiya/p/16631620.html