react render props模式实现组件复用示例

目录
  • 一 render props的使用步骤
  • 二 组件的复用
  • 三 使用children名代替属性

一 render props的使用步骤

1 创建要复用的组件,在组件中提供要复用的状态逻辑代码
2 将要复用的state作为方法的参数,暴露到组件外部

import React from "react";
import ReactDOM from "react-dom";

class App extends React.Component {

    render() {
        return <Mouse show={(mouse)=><p>鼠标所在位置:{mouse.x},{mouse.y}</p>}/>
    }

}

//1 创建要复用的组件,在组件中提供要复用的状态逻辑代码
class Mouse extends React.Component {

    state = {
        x: 0,
        y: 0
    }

    //监听鼠标移动时间
    componentDidMount() {
        window.addEventListener("mousemove", this.handleMouseMove)
    }

    //鼠标移动的事件处理
    handleMouseMove = e => {
        this.setState({
            x: e.clientX,
            y: e.clientY
        })
    }

    render() {
        //2 将要复用的state作为方法的参数,暴露到组件外部
        return this.props.show(this.state)
    }
}

ReactDOM.render(<App/>, document.getElementById("root"));

效果

二 组件的复用

实现鼠标移动,图片移动

import imgage from "./images/cat2.gif"

class App extends React.Component {

    render() {
        return <Mouse show={mouse => {
            return <img src={imgage} alt='猫' style={{
                position: 'absolute',
                // 为了让鼠标在图片的中间,top减掉了图片的一半高度,left减掉了图片一半的宽度
                top: mouse.y-198,
                left: mouse.x-250
            }}/>
        }}></Mouse>
    }
}

效果:图片跟着鼠标走

完整代码

import React from "react";
import ReactDOM from "react-dom";
import imgage from "./images/cat2.gif"

class App extends React.Component {

    render() {
        return <Mouse show={mouse => {
            return <img src={imgage} alt='猫' style={{
                position: 'absolute',
                // 为了让鼠标在图片的中间,top减掉了图片的一半高度,left减掉了图片一半的宽度
                top: mouse.y-198,
                left: mouse.x-250
            }}/>
        }}></Mouse>
    }
}

//1 创建要复用的组件,在组件中提供要复用的状态逻辑代码
class Mouse extends React.Component {

    state = {
        x: 0,
        y: 0
    }

    //监听鼠标移动时间
    componentDidMount() {
        window.addEventListener("mousemove", this.handleMouseMove)
    }

    //鼠标移动的事件处理
    handleMouseMove = e => {
        this.setState({
            x: e.clientX,
            y: e.clientY
        })
    }

    render() {
        //2 将要复用的state作为方法的参数,暴露到组件外部
        return this.props.show(this.state)
    }
}

ReactDOM.render(<App/>, document.getElementById("root")
);

三 使用children名代替属性

代码

import React from "react";
import ReactDOM from "react-dom";
import imgage from "./images/cat2.gif"

class App extends React.Component {

    render() {
        return <Mouse>
            {mouse => {
                return <img src={imgage} alt='猫' style={{
                    position: 'absolute',
                    // 为了让鼠标在图片的中间,top减掉了图片的一半高度,left减掉了图片一半的宽度
                    top: mouse.y - 198,
                    left: mouse.x - 250
                }}/>
            }}
        </Mouse>
    }
}

//1 创建要复用的组件,在组件中提供要复用的状态逻辑代码
class Mouse extends React.Component {

    state = {
        x: 0,
        y: 0
    }

    //监听鼠标移动时间
    componentDidMount() {
        window.addEventListener("mousemove", this.handleMouseMove)
    }

    //鼠标移动的事件处理
    handleMouseMove = e => {
        this.setState({
            x: e.clientX,
            y: e.clientY
        })
    }

    render() {
        //2 将要复用的state作为方法的参数,暴露到组件外部
        return this.props.children(this.state)
    }
}

ReactDOM.render(<App/>, document.getElementById("root")
);

到此这篇关于react render props模式实现组件复用示例的文章就介绍到这了,更多相关react render props组件复用内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • 谈谈React中的Render Props模式

    概述 Render Props模式是一种非常灵活复用性非常高的模式,它可以把特定行为或功能封装成一个组件,提供给其他组件使用让其他组件拥有这样的能力,接下来我们一步一步来看React组件中如何实现这样的功能. 简要介绍:分离UI与业务的方法一直在演进,从早期的mixins,到HOC,再到Render Prop,本文主要对比HOC,谈谈Render Props 1 . 早期的mixins 早期复用业务通过mixins来实现,比如组件A和组件B中,有一些公用函数,通过mixins剥离这些公用部分,并

  • 使用react render props实现倒计时的示例代码

    react的组件模式可以观看Michael Chan的演讲视频,平时大家常听到的react模式也是HOC, HOC的使用场景很多,譬如react-redux的connect,这里不赘述HOC相关,感兴趣可以自行了解. 首先是这样一个场景,我的业务需要实现倒计时,倒计时你懂得,倒计时经常应用在预告一个活动的开始,像秒杀,像开售抢购等,或者活动的截止. 我们来梳理一下这个倒计时的功能: 定时更新时间,以秒为度; 可以更新倒计时的截止时间,比如从10月1日更新为10月2日: 倒计时结束,执行对应结束逻

  • react render props模式实现组件复用示例

    目录 一 render props的使用步骤 二 组件的复用 三 使用children名代替属性 一 render props的使用步骤 1 创建要复用的组件,在组件中提供要复用的状态逻辑代码2 将要复用的state作为方法的参数,暴露到组件外部 import React from "react"; import ReactDOM from "react-dom"; class App extends React.Component { render() { ret

  • React Render Props共享代码技术

    目录 介绍 使用 使用children prop代替render prop Render props 与 React.PureComponent 同时使用 注意 解决方案 介绍 Render Props是指在React组件之间使用一个值为函数的prop共享代码的技术 具有render prop的组件接受一个返回React元素的函数,并在组件内部通过调用此函数来实现自己的渲染逻辑 主要用于抽离逻辑,进行代码复用 使用 以官方文档的Mouse & Cat示例为例 创建Mouse组件,此组件仅用于提供

  • react的滑动图片验证码组件的示例代码

    业务需求,需要在系统登陆的时候,使用"滑动图片验证码",来验证操作的不是机器人. 效果图 使用方式 在一般的页面组件引用即可.onReload这个函数一般是用来请求后台图片的. class App extends Component { state = { url: "" } componentDidMount() { this.setState({ url: getImage() }) } onReload = () => { this.setState({

  • React 高阶组件与Render Props优缺点详解

    目录 高阶组件 增强型高级组件 注入型高阶组件 高阶组件 VS Render Props 总结 高阶组件 高阶组件(HOC)是一个接受组件作为参数并返回一个新组件的函数,如果多个组件有相同的逻辑,将这些逻辑用函数封装,使它们能跨组件共用,这种用法称为高阶组件.下面的代码演示什么是高阶组件: export default function WithPrintLog(InnerComponent) { return class extends React.Component{ componentDi

  • React 模式之纯组件使用示例详解

    目录 什么是纯组件 纯组件解决了什么问题 怎么使用纯组件 CC: shouldComponentUpdate() 和 React.PureComponent FC: React.memo() 你可能并不需要纯组件 什么是纯组件 纯组件(Pure Component)这概念衍生自纯函数.纯函数指的是返回结果只依赖于传入的参数,且对函数作用域外没有副作用的函数.这种函数在相同参数下,返回结果是不变的.纯函数的返回值能被安全地缓存起来,在下次调用时,跳过函数执行,直接读取缓存.因为函数没有外部副作用,

  • 使用 React Hooks 重构类组件的示例详解

    目录 1. 管理和更新组件状态 2. 状态更新后的操作 3. 获取数据 4. 卸载组件时清理副作用 5.  防止组件重新渲染 6. Context API 7. 跨重新渲染保留值 8. 如何向父组件传递状态和方法? 9. 小结 最初,在 React 中可以使用 createClass 来创建组件,后来被类组件所取代.在 React 16.8 版本中,新增的 Hooks 功能彻底改变了我们编写 React 程序的方式,使用 Hooks 可以编写更简洁.更清晰的代码,并为创建可重用的有状态逻辑提供了

  • React路由拦截模式及withRouter示例详解

    目录 一.路由拦截 二.路由模式 三.withRouter 一.路由拦截 在前面两篇 路由博客基础上,我们将ReactRouter.js的我的profile路由设置成路由拦截的: <Route path="/profile" render={() => isAuth() ? <Profile/> : <Redirect to="/login"></Redirect> }></Route> 新建Logi

  • react实现Radio组件的示例代码

    本文旨在用最清楚的结构去实现一些组件的基本功能.希望和大家一起学习,共同进步 效果展示: 测试组件: class Test extends Component { constructor(props) { super(props) this.state = { active:1 } } onGroupChange(value) { this.setState({ active: value }) } render() { return ( <div> <RadioGroup onChan

随机推荐