首页 > 编程语言 >React@16.x(45)路由v5.x(10)源码(2)- history

React@16.x(45)路由v5.x(10)源码(2)- history

时间:2024-07-02 22:31:24浏览次数:22  
标签:10 函数 16 对象 地址 源码 location action history

目录

1,作用

react-router 在控制和监听地址变化时,使用的是第3方库 history,其中,

所以下面介绍的是 history v4.10.1 的 API,和 v5.0 是有差异的,注意区分。

另外,该对象不是 window.history,而是一个抽离的对象,它提供统一的 API 接口,封装了具体的实现。

  • createBrowserHistory,创建控制 浏览器真实地址history对象;
  • createHashHistory 创建控制 浏览器 hashhistory对象;
  • createMemoryHistory 创建控制 内存中地址栈history对象(一般用于没有地址栏的环境,比如 APP 中)。

它们3个共同的特点:

  • 维护了一个地址栈
  • 返回的 history 对象结构完全一致。

v5 版本,在使用下面3个方法时,已经没有配置项了。

1.1,createBrowserHistory

配置项

  • basename:设置根路径。
  • forceRefresh:地址改变时是否强制刷新页面。
  • keyLength:location对象使用的 key 值长度。
    • 地址栈中记录的并非字符串,而是一个 location 对象。
  • getUserConfirmation:一个函数,该函数当调用 history.block()后,发生页面跳转时运行。

1.2,createHashHistory

配置项:

  • hashType#号后给定的路径格式(注意 # 后的内容)
    • hashbang:被chrome弃用,#!路径
    • noslash#a/b/c
    • slash#/a/b/c

1.3,createMemoryHistory

略。

2,history 对象的属性

官方API介绍

2.1,action

当前地址栈,最后一次操作的类型。(该属性没什么用)

  • 如果是通过 createXXXHistory 函数新创建的 history 对象,action 固定为 POP
  • 如果调用了 history.push()action 变为 PUSH;同理调用 history.replace(),会变为 REPLACE
  • 其他的 gogoForward 等方法,不会改变 action

只要是新创建historyaction 都是 POP
比如通过已创建的 history 执行了 push 操作,action 变为 PUSH。此时再次创建新的 history 对象,action 又会变为 POP

2.2,push / replace / go / goBack / goForward

这些顾名思义,不多赘述。

2.3,location

表示当前地址中的信息,包括的属性(和 react-router 中的一样):

{
    "pathname": "/",
    "search": "",
    "hash": "",
    "state": null,
    "key": "xfadfd"
}

key 属性,是为了区分2个相同的地址。因为在地址栈中,存储的是 location 对象,通过 key 做唯一性判断。

2.4,listen

在之前的文章 React 路由守卫 中已经介绍了使用方式。
react-router 实现无刷新跳转的关键。

用于监听地址栈指针的变化。该函数接收一个函数作为参数,该参数表示地址变化后要做的事情

参数函数接收两个参数:

  • location:记录了新的地址信息;
  • action:进入新地址的方式:
    • POP:调用 gogoBackgoForward、用户点击浏览器后退按钮。
    • PUSH / REPLACE

该函数有一个返回值,返回的是一个函数,用于取消监听。

2.5,block / getUserConfirmation

同样的,在之前的文章 React 路由守卫 中已经介绍了使用方式。

block 用于设置一个阻塞,当页面发生跳转时,会将指定的消息传递到getUserConfirmation,并调用 getUserConfirmation 函数。

  • block 函数接收一个字符串作为参数,表示消息内容。也可以接收一个函数作为参数,函数的返回值是消息内容。
    该函数返回一个取消函数,调用取消函数可以解除阻塞。

2.5,createHref

返回一个可以直接作为 <a href=""> 的字符串,其实就是 bashname + url

const href= history.createHref(location);

以上。

标签:10,函数,16,对象,地址,源码,location,action,history
From: https://blog.csdn.net/qq_40147756/article/details/139908692

相关文章

  • 集中式DTU与4、6、8、12、16回路DTU主控单元
    一、集中式DTU集中式DTU适用范围:集中式DTUAPT-6600站所终端适用于配电系统中变电站、户外开闭所、箱变、开关站、环网柜、配电室等场合中的检测和控制需求。集中式DTU主要功能:采集配电网实时运行数据进行处理和分析,通过通信通道(如光纤、载波、无线等),上传至配网主站,并......
  • 完全图解RAID存储技术:RAID 0、1、5、6、10、50、60
    转自:https://cloud.tencent.com/developer/article/2304179什么是RAID存储?独立磁盘冗余阵列(RAID)是一种存储技术,通过将两个或多个硬盘驱动器(HDD)或固态硬盘(SSD)合并成一个协调的存储单元或阵列,从而创建数据丢失的故障安全机制。RAID存储通过将数据重复或重新创建,并将其存储在......
  • 批量视频创作:PlugLink如何助力大规模视频生成(附源码)
    批量视频创作:PlugLink如何助力大规模视频生成传统的视频制作流程往往需要大量的人力、物力和时间投入,这不仅限制了内容产出的效率,也大大提高了成本。为了解决这一问题,PlugLink,一个开源的自动化框架,为我们提供了一种全新的解决方案。什么是PlugLink?PlugLink是一个旨在帮助......
  • 基于SpringBoot+Vue+uniapp的论文管理系统的详细设计和实现(源码+lw+部署文档+讲解等)
    文章目录前言详细视频演示具体实现截图技术栈后端框架SpringBoot前端框架Vue持久层框架MyBaitsPlus系统测试系统测试目的系统功能测试系统测试结论为什么选择我代码参考数据库参考源码获取前言......
  • 专题五:Spring源码之初始化容器上下文
    上一篇我们通过如下一段基础代码作为切入点,最终找到核心的处理是refresh方法,从今天开始正式进入refresh方法的解读。publicclassMain{ publicstaticvoidmain(String[]args){ ApplicationContextcontext=newClassPathXmlApplicationContext("applicationContext......
  • opencascade AIS_InteractiveContext源码学习7 debug visualization
    AIS_InteractiveContext前言交互上下文(InteractiveContext)允许您在一个或多个视图器中管理交互对象的图形行为和选择。类方法使这一操作非常透明。需要记住的是,对于已经被交互上下文识别的交互对象,必须使用上下文方法进行修改。如果交互对象尚未加载到交互上下文中,您才......
  • LLaMA-Factory/scripts/length_cdf.py 源码解析
    这段代码定义了一个函数 length_cdf,用来计算和打印数据集样本长度的累积分布函数(CDF),并在脚本直接运行时通过 fire 库将该函数暴露为命令行接口。我们逐行解释这段代码:python复制fromllmtuner.dataimportget_datasetfromllmtuner.hparamsimportget_train_argsfrom......
  • [集训队互测2016] Unknown
    经典题,国赛前才做怎么回事。一句话题意:末尾加删,区间询问凸包信息。一个做法是建出操作树,发现本题相当于路径查询凸包信息。于是可以树剖/点分治。点分治的话可以转化成只有前缀询问的情况用平衡树维护图报加入一个点和回退。但是这样太难写了!观察到询问只有直上直下的链(当然如果......
  • 代理IP的10大误区:区分事实与虚构
    在当今的数字时代,代理已成为在线环境不可或缺的一部分。它们的用途广泛,从增强在线隐私到绕过地理限制。然而,尽管代理无处不在,但仍存在许多围绕代理的误解。在本博客中,我们将探讨和消除一些最常见的代理误解,阐明其真实性质和用法。1.代理保证绝对匿名关于代理的最普遍误解之......
  • 基于web实现的物业管理系统项目(运行视频+源码+数据库+部署文档)
    项目描述文档1.项目概述本项目旨在开发一个综合性物业管理系统,涵盖了保安保洁管理、保修管理、房产信息管理、公告管理、管理员信息管理、业主信息管理和登录管理等多个功能模块。该系统使用了JSP作为前端页面的开发技术,结合Bootstrap和jQuery进行页面设计和交互,后端则使用J......