react-DOM

react-dom作用

react-dom是react剥离出的涉及DOM操作的部分。
react的核心思想是虚拟DOM,react包含了生成虚拟DOM的函数react.createElement,及Component类。当我们自己封装组件时,就需要继承Component类,才能使用生命周期函数等。而react-dom包的核心功能就是把这些虚拟DOM渲染到文档中变成实际DOM。
react-dom主要包含三个API:findDOMNode,unmountComponentAtNode和render。

1. render

render用于将React渲染的虚拟DOM渲染到浏览器DOM,一般在顶层组件使用。该方法把元素挂载到container中,并且返回element的实例(即refs引用),如果是无状态组件,render会返回null。当组件装载完毕时,callback就会被调用。其语法为:
render(ReactElement element,DOMElement container,[function callback])

import React from 'react'
import ReactDOM from 'react-dom'
import Router from './router'
import { Provider } from 'react-redux'
import store from './store'
// Provider react-redux的内容
ReactDOM.render(
  <Provider store={store}>
    <Router/>
  </Provider>, document.getElementById('root'))

2. findDOMNode

findDOMNode用于获取真正的DOM元素,以便对DOM节点进行操作。
在此之前,首先要知道:在React中,虚拟DOM真正被添加到HTML中转变为真实DOM是在组件挂载(render())后,故而我们可以在componentDidMount和componentDidUpdate这两个方法中获取。

import { findDOMNode } from 'react-dom';

<Example ref={ node=>{ this.node = node} }> // 利用ref获取Example组件的实例

const dom = findDOMNode(this.node); // 通过findDOMNode获取实例对应的真实DOM

注:当涉及复杂操作时,还有很多元素DOM API可用,然而DOM操作会对性能产生很大影响,所以,应当尽量减少DOM操作。

3. unmountComponentAtNode

unmountComponentAtNode用于执行卸载操作,执行在componentWillUnmount之前。

posted @ 2022-07-04 16:28  白日梦想家er  阅读(1113)  评论(0编辑  收藏  举报