React第五讲课堂笔记(DOM操作)

1. React 中获取DOM的两种方式

  • ReactDOM.findDOMNode
  • this.refs.xxx

获取DOM后可以方便结合现有非 react 类库的使用,通过 ref/refs 可以取得组件实例,进而取得原生节点,不过尽量通过 state/props 更新组件,不要使用该功能去更新组件的DOM。

2. 示例一

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
import React, { Component } from 'react';
import ReactDOM, { findDOMNode } from 'react-dom';

class HandleDOMComponent extends Component {
componentDidMount(){
// 两种方式都可以获取到元素
let ele = findDOMNode(this.refs.content);
let ele2 = this.refs.content;

// 如果想用 jquery,那么这是个好时机
console.log( ele );
console.log( ele.innerHTML );
console.log( ele2.innerHTML );

}

render(){
return (
<div>
<h3>来吧,一起操作DOM</h3>
<div ref='content'>这是我DOM元素里面的内容</div>
</div>
);
}
}

export default HandleDOMComponent;

3. 示例二

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
39
40
41
42
43
44
45
import React, { Component } from 'react';
import { findDOMNode } from 'react-dom';

class Refs extends Component {
state = {
red: 0,
green: 0,
pink: 0
}
update = (e) => {
this.setState({
red: findDOMNode(this.refs.red).value,
green: findDOMNode(this.refs.green).value,
pink: findDOMNode(this.refs.pink).value
})
}
render(){
return (
<div>
<Slider ref="red" update={this.update} />
{this.state.red}
<br />
<Slider ref="green" update={this.update} />
{this.state.green}
<br />
<Slider ref="pink" update={this.update} />
{this.state.pink}
</div>
)
}
}

class Slider extends Component {
render(){
return (
<input type="range"
min="0"
max="255"
onChange={this.props.update} />
)
}

}

export default Refs;