React中react-redux和路由详解

 更新时间:2022年08月28日 16:27:45   作者:公众号_前端每日技巧  
这篇文章主要介绍了React中react-redux和路由详解,redux早期被设计成可以在各个框架中使用,因此在不同的框架中使用的时候,要引入相应的插件,感兴趣的朋友可以继续学习下面文章

观察者模式解决组件间通信问题

使用观察者解决组件间通信,分成两步

  • 在一个组件中,订阅消息
  • 在另一个组件中,发布消息

发布消息之后,订阅的消息回调函数会执行,在函数中,我们修改状态,这样就可以实现组件间通信了。这就是reflux框架的实现。

react-redux

redux早期被设计成可以在各个框架中使用,因此在不同的框架中使用的时候,要引入相应的插件

在react中使用要引入react-redux,因此我们要安装这个模块

npm install react-redex

react-redux提供了一个方法和一个组件:

connect方法

为组件的属性拓展store中的信息(state,dispatch)的方法

connect方法有两个参数,都是函数

第一个参数表示如何为组件的属性拓展store中的state数据

参数是state

返回值是对象,就是为属性拓展的数据

第二个参数表示如何为组件的属性拓展store中的dispatch方法

参数就是dispatch

返回值是对象,就是为属性拓展的方法

connect方法的返回值是一个新方法,就是为组件拓展的方法。

参数是组件

返回值是新组件,这个新的组件就拥有了state数据和dispatch方法了

Provider组件

用来为应用程序提供store对象的组件

store属性,就是绑定添加的store

Provider组件中我们可以渲染应用程序组件

在应用程序中,这些被connect方法处理的组件就会接收store中的数据了

注意:只有通过connect的处理方法处理之后的组件具有state和dispatch,其他的组件没有这些信息

想让其它组件具有store中的state和dispatch,有两种途径:

  • 第一种,具有state数据和dispatch方法的组件中,向子组件传递(最常用)
  • 第二种,再用处理方法,处理其他的组件。

路由

从14版本开始,react路由为了实现react多端适配的理想,将react路由拆分成不同类型的。

例如在web端要使用web端路由,在native端要使用nativate路由等等

我们开发web端,要安装react-router-dom路由

npm install react-router-dom

使用路由

使用路由分成三步:

第一步 定义路由渲染容器元素(渲染位置)

  • 可以通过Swtich组件定义
  • 可以通过Route组件定义每一条路由规则
  • path 定义路由规则
  • component定义路由渲染的组件
  • name 定义路由的名称

第二步 定义路由的渲染方式(规则)

常用的有两种:

  • BrowserRouter:基于path,实现的路由规则,需要服务器端的配合
  • HashRouter:基于hash,实现的路由规则,不需要服务器端配合
    • 我们通过路由渲染模式组件,渲染应用程序
    • 将应用程序组件,定义在该组件内

第三步 用render方法,渲染第二步得到的结果

默认路由

在react路由中,让path匹配*,即可定义默认路由

由于​​*​​匹配的非常广,因此我们常常把它配置在最后面

路由重定向

我们通过Redirect组件定义重定向路由

from定义匹配的规则

to定义重定向的规则

获取路由参数

在react中,我们​​使用路由的组件​​,会自动拓展一些属性

history表示对全局的history历史对象的模拟

location表示对全局的location对象的模块,但是只是处理路由这一部分

match表示路由数据对象(解析后的数据,因此工作中常用)

其他没有通过路由渲染的组件是不具备这些信息,想具有这些信息,我们可以通过组件间通信的技术,依次传递这些数据信息

路由导航

我们通过Link组件定义路由导航

通过to属性定义导航地址,即使是hash路由也不要加#

默认渲染成a标签

举例:

// 引入路由
import { Switch, Route, HashRouter, Redirect, Link } from 'react-router-dom';
// 应用程序
class App extends Component {
render() {
console.log('app', this)
return (
<div>
<h1>app</h1>
{/*导航*/}
<Link to="/home">首页</Link>
<Link to="/list/17">列表页</Link>
<Link to="/detail/17">详情页</Link>
{/*第一步 定义路由渲染位置*/}
<Switch>
{/*Route定义规则*/}
<Route path="/home" component={Home}></Route>
<Route path="/list/:page" component={List}></Route>
<Route path="/detail/:id" component={Detail}></Route>
{/*输入ickt进入detail/ickt详情页*/}
<Redirect from="/ickt" to="/detail/ickt"></Redirect>
{/*默认路由*/}
<Route path="*" component={Home}></Route>
</Switch>
</div>
)
}
}
// 首页
class Home extends Component {
render() {
console.log('home', this)
return (
<div>
<h1>home</h1>
</div>
)
}
}
// 列表页
class List extends Component {
render() {
console.log('list', this)
return (
<div>
<h1>list</h1>
</div>
)
}
}
// 详情页
class Detail extends Component {
render() {
console.log('detail', this)
// 解构数据
let { history, match } = this.props;
return (
<div>
<h1>detail</h1>
<Demo history={history} match={match}></Demo>
</div>
)
}
}
// 详情页
class Demo extends Component {
render() {
console.log('demo', this)
return (
<div>
<h2>demo</h2>
</div>
)
}
}
// 第二步 确定渲染方式
let routes = (
<HashRouter>
<App></App>
</HashRouter>
)
// 第三步 渲染第二步结果
render(routes, app)

到此这篇关于React中react-redux和路由详解的文章就介绍到这了,更多相关React react-redux 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • react中关于useCallback的用法

    react中关于useCallback的用法

    这篇文章主要介绍了react中关于useCallback的用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-06-06
  • react中使用Modal.confirm数据不更新的问题完美解决方案

    react中使用Modal.confirm数据不更新的问题完美解决方案

    这篇文章主要介绍了react中使用Modal.confirm数据不更新的问题解决方案,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2023-09-09
  • React.js绑定this的5种方法(小结)

    React.js绑定this的5种方法(小结)

    this在javascript中已经相当灵活,这篇文章主要介绍了React.js绑定this的5种方法(小结),小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-06-06
  • 前端开发使用Ant Design项目评价

    前端开发使用Ant Design项目评价

    这篇文章主要为大家介绍了前端开发使用Ant Design项目评价,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-08-08
  • React控制元素显示隐藏的三种方法小结

    React控制元素显示隐藏的三种方法小结

    这篇文章主要介绍了React控制元素显示隐藏的三种方法小结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-12-12
  • create-react-app开发常用配置教程

    create-react-app开发常用配置教程

    这篇文章主要为大家介绍了create-react-app开发常用配置教程示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • react native 文字轮播的实现示例

    react native 文字轮播的实现示例

    这篇文章主要介绍了react native 文字轮播的实现示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-07-07
  • React中的路由嵌套和手动实现路由跳转的方式详解

    React中的路由嵌套和手动实现路由跳转的方式详解

    这篇文章主要介绍了React中的路由嵌套和手动实现路由跳转的方式,手动路由的跳转,主要是通过Link或者NavLink进行跳转的,实际上我们也可以通JavaScript代码进行跳转,需要的朋友可以参考下
    2022-11-11
  • 浅谈React原生APP更新

    浅谈React原生APP更新

    当一个APP在运行的时候, 开发者想要将自己的代码更新到用户的手机上时, 一般都有两种方案, 一是热更新, 二就是APP更新.热更新暂且不说,这篇文章就讲讲 APP 如何更新。
    2021-06-06
  • React组件通信的实现示例

    React组件通信的实现示例

    在React中,组件通信是一个重要的概念,它允许不同组件之间进行数据传递和交互,本文主要介绍了React组件通信的实现示例,感兴趣的可以了解一下
    2023-11-11

最新评论