当前位置: 首页 > news >正文

卫生局网站模板asp网站增加新栏目在哪添加

卫生局网站模板,asp网站增加新栏目在哪添加,上海企业网站建设方法,合肥网站制作套餐一、整体架构 三大核心库与对应的组件 history -> react-router -> react-router-dom react-router 可视为react-router-dom 的核心&#xff0c;里面封装了<Router>&#xff0c;<Route>&#xff0c;<Switch>等核心组件,实现了从路由的改变到组件的更新…

一、整体架构

三大核心库与对应的组件

        history -> react-router -> react-router-dom

  • react-router 可视为react-router-dom 的核心,里面封装了<Router>,<Route>,<Switch>等核心组件,实现了从路由的改变到组件的更新的核心功能。以及配套方法、hook。这部分只和 react 有关,和宿主无关,像 在初始化的时候,必须手动传入宿主对 history api 的实现。
  • react-router-dom 则是 react-router 在浏览器宿主下的更上一层封装。把浏览器 history api 传入<Router> 并初始化成 <BrowserRouter>、<HashRouter>,补充了 <Link> 这样给浏览器直接用的组件。同时把 react-router 透传导出,减少开发者依赖。
  • history 库可视为react-router的核心,也是整个路由原理的核心,里面集成了popState,history.pushState等底层路由实现的原理方法。给 browser、hash 两种 history 统一了 api,补充了订阅的能力,最终规范成 react-router 需要的接口供 react-router-dom 调用。

二、history库详解

模块划分:

  • history 依赖 window.history API:用于同步的增删改查浏览器路由状态
  • history 依赖 event listener 监听浏览器路由事件:用于处理自身状态和回调
  • 转接层:实现 window.history.state 和自身 location 数据的双向转换
  • location:history 维护的 location 数据,全局唯一
  • 订阅池:自己实现了回调池子,通过 push、call 方法添加订阅和修改
  • 路由方法:间接调用 window.history 的方法

主要调用逻辑:

  • 初始化(执行 createBrowserHistory):创建location、订阅池、方法;从 window.location、window.history 计算当前 location。
  • 浏览器事件触发:重新计算当前 location;调订阅池 call 方法处理所有回调
  • push、replace 方法被调用:根据调用入参生成新 location,并转为 history state,调 window.history 方法;调订阅池 call 方法处理所有回调.

三、路由流程分析:

当地址栏改变url,组件的更新渲染都经历了什么?😊😊😊 拿history模式做参考。当url改变,首先触发histoy,调用事件监听popstate事件, 触发回调函数handlePopState,触发history下面的setstate方法,产生新的location对象,然后通知Router组件更新location并通过context上下文传递,switch通过传递的更新流,匹配出符合的Route组件渲染,最后有Route组件取出context内容,传递给渲染页面,渲染更新。

在切换不同的组件中,有俩种方式,push和replace。

默认的是push,即每切换url,之前的路由仍然在history栈中。

如果切换默认使用的是replace,则当前的URL路由会替换掉栈顶的路由记录。

 <Link push = {true} to={{pathname:'/home/message/detail',state:{id:msgObj.id,title:msgObj.title}}}>{msgObj.title}</Link>

 

http://www.yayakq.cn/news/873083/

相关文章:

  • 交换链接的方法上海seo优化外包公司
  • 湛江做网站建设石家庄最新招聘信息
  • 远程教育网站建设方案平面设计提升培训中心
  • 网站建设经济可行性烟台电子商务网站
  • 小说网站制作模板学校网站建设年度总结
  • 信阳网站开发建设公司amp for wordpress
  • 流浪动物网站开发建筑模板多少钱一张什么尺寸
  • 网站制作模板网站室内设计效果图手绘图片大全
  • 有了域名和空间怎么建网站上海工程咨询协会官网
  • 邯郸专业网站建设梵克雅宝官网中国官网
  • 超低价网站维护网站托管做类图的网站
  • 可以做推广东西的网站一个网站如何做桌面快捷链接
  • 网站开发手机编译器整合营销策划名词解释
  • 做360全景有什么网站wordpress新增站点
  • 可以做设计私单的网站建设机械网站咨询
  • 云主机安装网站做网站怎么写预算
  • 模仿网站制作朝阳网站建设推广
  • 贵阳市建设厅官方网站网站备案 前置审批文件
  • 个人名义做网站南京中企动力有限公司
  • 软文网站学用php做网站
  • 怎样经营好一个网站建设区服务网站
  • 怎么创建网站教程网站返回首页怎么做的好看
  • 黄石网站建设凡科建站下载
  • 网站制作软件排名怎么推广自己的店铺
  • 网站建设培训会讲话网站作业免费下载
  • 平顶山网站建设遵义网约车有哪些平台
  • 高端h5手机网站设计案例跨境电商平台推广
  • pdf文件打印乱码seo关键词排名优化联系方式
  • 免费注册网站免登录个人未授权做的网站
  • 最专业的营销网站建设公司wordpress拖拽式布局