zoukankan      html  css  js  c++  java
  • vue-Router两种模式

    前端路由概念

    通过改变 URL,在不重新请求页面的情况下,更新页面视图。

    Hash — 默认值,利用 URL 中的hash("#") 、

    history-- 利用URL中的路径(/home)

    如何设置路由模式:

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

    mode 区别:

    hash多了'#'

    http://localhost:8080/#/login
    

    history正常

    http://localhost:8080/login
    

    Hash

    拥有两个方法,一个是 push, 一个是 replace

    两个方法:HashHistory.push() 和 HashHistory.replace()
    

    HashHistory.push() 将新路由添加到浏览器访问历史的栈顶

    HashHistory.replace()replace()方法与push()方法不同之处在于,它并不是将新路由添加到浏览器访问历史的栈顶,而是替换掉当前的路由

    History

    早期History通过back()、forward()、go()等方法,我们可以读取浏览器历史记录栈的信息
    从HTML5开始History提供了2个新的方法:pushState()、replaceState()
    使得我们可以对浏览器历史记录栈进行修改:

    pushState()

    window.history.pushState(data, title, targetURL);
    @状态对象:传给目标路由的信息,可为空
    @页面标题:目前所有浏览器都不支持,填空字符串即可
    @可选url:目标url,不会检查url是否存在,且不能跨域。如不传该项,即给当前url添加data
    
    

    replaceState()

    window.history.replaceState(data, title, targetURL);
    @类似于pushState,但是会直接替换掉当前url,而不会在history中留下记录
    

    特点:

    这2个方法有个共同的特点:当调用他们修改浏览器历史栈后,虽然当前url改变了,但浏览器不会立即发送请求该url,这就为单页应用前端路由,更新视图但不重新请求页面提供了基础

  • 相关阅读:
    .NET下的加密解密大全(1): 哈希加密
    orm fluentdata使用相关文章
    xml处理相关文章收藏
    Salty Fish(区间和)
    Fennec VS. Snuke
    Splitting Pile
    ST表(离线RMQ)
    Exponentiation(高精度大数)
    高斯消元(模板)
    Online Judge(字符串-格式)
  • 原文地址:https://www.cnblogs.com/luckyjiu9/p/13890692.html
Copyright © 2011-2022 走看看