首页 web前端 js教程 使用React将组件渲染到指定DOM节点

使用React将组件渲染到指定DOM节点

Apr 18, 2018 am 11:51 AM
react 指定 渲染

这次给大家带来使用React将组件渲染到指定DOM节点,使用React将组件渲染到指定DOM节点的注意事项有哪些,下面就是实战案例,一起来看一下。

众所周知React优点之一就是他的API特别简单。通过render 方法返回一个组件的基本结构,如同一个简单的函数,就可以得到一个可以复用的react组件。但是有时候还是会有些限制的,尤其是他的API中,不能控制组件所应该渲染到的DOM节点,这就让一些弹层组件很难控制。当父元素设置为<a href="http://www.php.cn/wiki/923.html" target="_blank">overflow</a>:hidden 的时候,问题就会出现了。

例如就像下面的这样:

我们实际期待的效果是这样的:

幸运的是,虽然不是很明显,但有一个相当优雅的方式来绕过这个问题。我们学到的第一个react函数是render 方法,他的函数签名是这样的:

1

2

3

4

5

ReactComponent render(

 ReactElement element,

 DOMElement container,

 [function callback]

)

登录后复制

通常情况下我们使用该方法将整个应用渲染到一个DOM节点中。好消息是该方法并不仅仅局限于此。我们可以在一个组件中,使用ReactDom.render 方法将另一个组件渲染到一个指定的DOM 元素中。作为一个组件的render 方法,其必须是纯净的(例如:不能改变state或者与DOM交互).所以我们需要在componentDidUpdate 或者 componentDidMount 中调用ReactDom.render 方法。

另外我们需要确保在父元素被卸载的时候,改组件也要被卸载掉.

整理下,我们得到下面的一个组件:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

import React,{Component} from 'react';

import ReactDom from 'react-dom';

export default class RenderInBody extends Component{

 constructor(p){

  super();

 }

 componentDidMount(){//新建一个p标签并塞进body

  this.popup = document.createElement("p");

  document.body.appendChild(this.popup);

  this._renderLayer();

 }

 componentDidUpdate() {

  this._renderLayer();

 }

 componentWillUnmount(){//在组件卸载的时候,保证弹层也被卸载掉

  ReactDom.unmountComponentAtNode(this.popup);

  document.body.removeChild(this.popup);

 }

 _renderLayer(){//将弹层渲染到body下的p标签

  ReactDom.render(this.props.children, this.popup);

 }

 render(){

  return null;

 }

}

登录后复制

总结下就是:

在componentDidMount的时候手动向body内塞一个p标签,然后使用ReactDom.render 将组件渲染到这个p标签

当我们想把组件直接渲染到body上的时候,只需要在该组件的外面包一层RenderInBody 就可以了.

1

2

3

4

5

6

7

export default class Dialog extends Component{

 render(){

  return {

   <RenderInBody>i am a dialog render to body</RenderInBody>

  }

 }

}

登录后复制

译者增加:

将以上组件改造一下,我们就可以向指定的dom节点中渲染和卸载组件,并加上位置控制,如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

//此组件用于在body内渲染弹层

import React,{Component} from 'react'

import ReactDom from 'react-dom';

export default class RenderInBody extends Component{

 constructor(p){

  super(p);

 }

 componentDidMount(){

  /**

  popupInfo={

   rootDom:***,//接收弹层组件的DOM节点,如document.body

   left:***,//相对位置

   top:***//位置信息

  }

  */

  let {popupInfo} = this.props; 

  this.popup = document.createElement('p');

  this.rootDom = popupInfo.rootDom;  

  this.rootDom.appendChild(this.popup);

  //we can setAttribute of the p only in this way

  this.popup.style.position='absolute';

  this.popup.style.left=popupInfo.left+'px';

  this.popup.style.top=popupInfo.top+'px';

  this._renderLayer()

 }

 componentDidUpdate() {

  this._renderLayer();

 }

 componentWillUnmount(){

  this.rootDom.removeChild(this.popup);

 }

 _renderLayer(){

  ReactDom.render(this.props.children, this.popup);

 }

 render(){

  return null;

 }

}

登录后复制

注:位置获取和根结点判断函数

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

export default (dom,classFilters)=> {

 let left = dom.offsetLeft,

  top = dom.offsetTop + dom.scrollTop,

  current = dom.offsetParent,

  rootDom = accessBodyElement(dom);//默认是body

 while (current !=null ) {

  left += current.offsetLeft;

  top += current.offsetTop;

  current = current.offsetParent;

  if (current && current.matches(classFilters)) {

   rootDom = current;

   break;

  }

 }

 return { left: left, top: top ,rootDom:rootDom};

}

/***

1. dom:为响应弹层的dom节点,或者到该dom的位置后,可以做位置的微调,让弹层位置更佳合适

*

2. classFilters:需要接收弹层组件的DOM节点的筛选类名

/

登录后复制

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

JS实现图片在网页中被拖拽

React Native组件的生命周期多长

以上是使用React将组件渲染到指定DOM节点的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

如何利用React和RabbitMQ构建可靠的消息传递应用 如何利用React和RabbitMQ构建可靠的消息传递应用 Sep 28, 2023 pm 08:24 PM

如何利用React和RabbitMQ构建可靠的消息传递应用引言:现代化的应用程序需要支持可靠的消息传递,以实现实时更新和数据同步等功能。React是一种流行的JavaScript库,用于构建用户界面,而RabbitMQ是一种可靠的消息传递中间件。本文将介绍如何结合React和RabbitMQ构建可靠的消息传递应用,并提供具体的代码示例。RabbitMQ概述:

React Router使用指南:如何实现前端路由控制 React Router使用指南:如何实现前端路由控制 Sep 29, 2023 pm 05:45 PM

ReactRouter使用指南:如何实现前端路由控制随着单页应用的流行,前端路由成为了一个不可忽视的重要部分。ReactRouter作为React生态系统中最受欢迎的路由库,提供了丰富的功能和易用的API,使得前端路由的实现变得非常简单和灵活。本文将介绍ReactRouter的使用方法,并提供一些具体的代码示例。安装ReactRouter首先,我们需

酷家乐怎么渲染正交俯视图_酷家乐渲染正交俯视图教程 酷家乐怎么渲染正交俯视图_酷家乐渲染正交俯视图教程 Apr 02, 2024 pm 01:10 PM

1、首先在酷家乐中打开要渲染的设计方案。2、然后在渲染菜单下打开俯视图渲染。3、接着在俯视图渲染界面中点击参数设置中的正交。4、最后调整好模型角度即可点击立即渲染,渲染正交俯视图。

PHP、Vue和React:如何选择最适合的前端框架? PHP、Vue和React:如何选择最适合的前端框架? Mar 15, 2024 pm 05:48 PM

PHP、Vue和React:如何选择最适合的前端框架?随着互联网技术的不断发展,前端框架在Web开发中起着至关重要的作用。PHP、Vue和React作为三种具有代表性的前端框架,每一种都具有其独特的特点和优势。在选择使用哪种前端框架时,开发人员需要根据项目需求、团队技能和个人偏好做出明智的决策。本文将通过比较PHP、Vue和React这三种前端框架的特点和使

Java框架与前端React框架的整合 Java框架与前端React框架的整合 Jun 01, 2024 pm 03:16 PM

Java框架与React框架的整合:步骤:设置后端Java框架。创建项目结构。配置构建工具。创建React应用。编写RESTAPI端点。配置通信机制。实战案例(SpringBoot+React):Java代码:定义RESTfulAPI控制器。React代码:获取并显示API返回的数据。

如何利用React开发一个响应式的后台管理系统 如何利用React开发一个响应式的后台管理系统 Sep 28, 2023 pm 04:55 PM

如何利用React开发一个响应式的后台管理系统随着互联网的快速发展,越来越多的企业和组织需要一个高效、灵活、易于管理的后台管理系统来处理日常的操作事务。React作为目前最受欢迎的JavaScript库之一,提供了一种简洁、高效和可维护的方式来构建用户界面。本文将介绍如何利用React开发一个响应式的后台管理系统,并给出具体的代码示例。创建React项目首先

如何解决在Windows上缺少MSVCP140D.dll的问题 如何解决在Windows上缺少MSVCP140D.dll的问题 Dec 22, 2023 am 10:51 AM

MSVCP140D.dll是一种非常重要的资源文件,如果在运行程序的时候出现了MSVCP140D.dll没有被指定在Windows上运行的错误那么就需要认真对待了,因为如果不好好处理程序是无法运行的。MSVCP140D.dll没有被指定在Windows上运行解决办法:方法一:首先下载msvcp140.dll文件解压后复制到对应的系统目录中即可(下面不同的目录地址对应的就是不同的系统不可以搞错)1、Windows95/98/Me系统,复制到C:\Windows\System目录下。2、Window

vue.js vs.反应:特定于项目的考虑因素 vue.js vs.反应:特定于项目的考虑因素 Apr 09, 2025 am 12:01 AM

Vue.js适合中小型项目和快速迭代,React适用于大型复杂应用。1)Vue.js易于上手,适用于团队经验不足或项目规模较小的情况。2)React的生态系统更丰富,适合有高性能需求和复杂功能需求的项目。

See all articles