学习react基础知识(三)

路由

手写路由

控制地址栏<Link to=‘/singer‘>歌手</Link>根据改变渲染不同的组件<Route path=‘/singer‘ component={要渲染的组价}><Route>

路由插件 react-router

1 - 3 :react-router 4 - 5 :react-router-dom react-router-nativereact-router

下载安装 npm install react-router-dom
路由的基本使用

HashRouter BrowserRouter 哈希路由 历史路由 作为组件的父容器控制地址栏的改变 to Link to exact NavLink to exact activeClassName

Route 控制组件的渲染 path exact component render children Switch 百里挑一 只返回第一个匹配到的组件Redirect 重定向

<HashRouter>  <Link exact to=‘/singer‘>歌手</Link>  <NavLink exact to=‘/recomment‘ activeClassName=‘hehe‘>推荐</NavLink>  <Switch>    <Redirect from=‘/‘ to=‘/singer‘ exact />    <Route path=‘/singer‘ component={组件}></Route>    <Route path=‘/recomment‘ render={组件}></Route>    <Route path=‘/singer‘ children={组件}></Route>    <Route component={404}>  </Switch></HashRouter>

编程式导航和声明式导航(寻找路由对象)

<Link><NavLink>实现路由的跳转 生命式导航t通过js路由对象的方式叫做编程式导航 push replace go goBack goForwd 注意 :正常创建的组件是没有路由对象的

  1. 通过Route 处理过的组件在props里有路由对象
  2. 通过withRouter 处理过的组件也有路由对象

路由传参

动态导航 /hehe/:id this.props.history.push(/singer/${us}/${ps}) 在路由对象的match 里获取传递的参数query /hehe?us=123&ps=123相当于get方法 接受数据在路由对象的 location里 需要自己做字符解析this.props.history.push(‘/singer?us=123&ps=456‘)state 在路由对象的location里接受this.props.history.push({pathname:‘/recommend‘,state:{要传递的数据}})

嵌套路由

在路由里套路由 所有的组价你都可以使用使用 Link Switch ..嵌套路由的上一级 千万不能加精准匹配<Route path=‘/singer‘ render={()=>{ <Route></Route> <Route></Route>}}></Route>

高阶组件

hoc 本质是一个函数 接受一个组件作为参数 返回一个新的组件功能性的封装 减少重复代码一般被高阶组件处理过的组件获取数据 都从props获取

原文地址:https://www.cnblogs.com/Frank000000/p/12547621.html

时间: 2024-10-08 02:00:15

学习react基础知识(三)的相关文章

学习react基础知识(四)

全局状态管理 Vue全局状态管理 vuex state mutation action getter module 辅助函数 redux 多组件共享状态,一个组件发生改变其他的都要变 在电视上剧里活不过3集 甄嬛传 慈禧太后 -> 光绪帝 -> 卖地求荣 ->闭关锁国 -> 垂帘听政 安装redux npm install redux 角色划分 皇帝 store 传递奏折 发布政令老佛爷 reducer 接受奏折 根据局奏折批阅平民百姓 component 使用数据 修改数据文武百

20_Shell语言———VIM编辑器基础知识三之窗口属性定制、配置文件及查找替换功能

Vim编辑器可以让用户按照需求来定制一些使用属性. 一.窗口属性定义 1)显示行号 行号不是内容,只是用来帮助用户确认文本所在的行.在vim编辑器中,如果要显示行号,可以在末行模式下输入: set number 如果想关闭,则可以在功能名称前面加上no,即: set nonumber 命令可以被简写,如set number 可以简写为 set nu:set nonumber 可以简写为 set nonu. 注意,上述设定仅对当前vim的进程有效,一旦当前进程关闭,这些设定就会失效,如果要使设定永

hadoop学习笔记——基础知识及安装

1.核心 HDFS  分布式文件系统    主从结构,一个namenoe和多个datanode, 分别对应独立的物理机器 1) NameNode是主服务器,管理文件系统的命名空间和客户端对文件的访问操作.NameNode执行文件系统的命名空间操作,比如打开关闭重命名文件或者目录等,它也负责数据块到具体DataNode的映射 2)集群中的DataNode管理存储的数据.负责处理文件系统客户端的文件读写请求,并在NameNode的统一调度下进行数据块的创建删除和复制工作. 3)NameNode是所有

Ant学习-001-ant 基础知识及windows环境配置

一.Ant 概要基础知识 Apache Ant 是一个将软件编译.测试.部署等步骤联系在一起加以自动化的一个工具,大多用于Java环境中的软件开发,用以构建应用,或结合其他开源测试工具例如 git.TestNG等搭建持续集成测试开发环境,从而高效.高质量的构建产品. Ant 有以下一些优点: 跨平台,可移植.Ant 是 Java 语言编写的,所以有很好的跨平台性和可移植性,无论是在 windows.Linux,还是 mac. 操作简单. Ant 是由一个内置任务和可选任务组成的,运行时需要一个构

Web前端学习①Web基础知识

<1>Web前端Web基础知识 一.前端工程师的角色 一个网站的建设需要以下角色: ①策划人员:方案 ②美工/UI设计师:设计图 (.psd  .rp) ③前端工程师:静态网页 ④后端工程师:获取数据 ( Java   PHP  .NET) 二.Web的基础知识 1.Web(万维网)与Internet(因特网) ①Internet简介:定义.主要服务.基本实现技术 ②Web与Internet关系 Web是Internet提供的服务. ③Web简介:万维网 2.Web的工作原理 ①Web的工作原

.net学习必备基础知识

进入21世纪,开发Windows程序已经成为以Dll为基础,而.NET  Framwork也日益成为我们开发软件的有利工具,下边我们就来先看一下,学习.net的一些必备基础知识. 一,首先.net是由公共语言执行时期(CLR)与基底类别库(BCL)组成.这两个东西是什么呢?我们先来看一下: 1,CLR是公共语言运行时,Common language Runtime 和Java虚拟机一样也是一个运行时环境,他负责资源管理(内存分配和垃圾收集),并保证应用和底层操作系统之间必要的分离.也就是给了我们

JAVA程序员需要学习哪些基础知识?

极客营认为想要成为一个合格的java程序员,必须需要牢固的基础,这样在未来接触新的知识的时候,才能快速吸收,极客营认为基础不牢固的程序员,随时都会被新的知识和技术所淘汰,下盘不稳风一吹就倒,那么作为一个合格的java程序员应该具备哪些知识呢?今天极客营就来和大家分享java高手之路上的必备基础知识: 一.面向对象的知识:JAVA是一个面向对象的开发语言,因此熟悉面向对象对学习JAVA很有必要,您要了解:什么是对象,什么是类;什么是封装,什么是多态,什么是继承;什么是抽象类,什么是接口.了解了概念

如何学习安卓(android)开发,需要学习哪些基础知识?

随着智能手机的流行,现在很多大大小小的开发商都需要在手机上具备客户端,这里是一片强大的吸金磁场,那么很多想学习android的朋友,都会有个疑问,那就是:安卓(android)应该怎么学,需要哪些基础知识? 下面是我根据自己和周围朋友的一些经验,总结出来的几点,希望对想学安卓(Android)开发的朋友有所帮助. 1.安卓(Android)开发的分类: (1)安卓(Android)底层开发:我们需要掌握C语音.Linux操作系统等比较底层的知识,以后的发展方向应该是驱动.嵌入式开发.协议开发.

web前端学习的基础知识1

Web前端是一个很新的职业,在国内乃至国际上真正开始受到重视的时间不超过5年.Web前端开发是从网页制作演变而来的,名称上有很明显的时代特征.目前看来,这个一个就业前景很大的职业. web前端的学习不能一蹴而就,也不是那么轻而易举就能够学会的,需要我们慢慢的去学习,去理解. 今天,给大家说的就是一些web前端学习中的一些基础知识. web前端中使用的语言不是我们人与人之间进行交流的语言,而是计算机语言.计算机的语言有很多种:C.PHP.Rudy.Java.C#.Basic.JS.....这里主要