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,这就为单页应用前端路由,更新视图但不重新请求页面提供了基础

  • 相关阅读:
    Jmeter之断言处理
    JMeter工具简单介绍
    TCP的三次握手和四次挥手
    浅谈cookie、session
    浅谈HTTP中Get与Post的区别
    DNS原理入门
    互联网协议简介
    测试与部署
    部分代码片段
    apache和php扩展问题
  • 原文地址:https://www.cnblogs.com/luckyjiu9/p/13890692.html
Copyright © 2011-2022 走看看