ReactJS学习系列课程(React ref的使用)
2017-06-24 14:59
411 查看
在我学习React的过程当中,总会被一些名词搞得晕头转向,但是细想起来又非常简单,比如react定义的这个refs,其实就是用于获取dom的一种方式。
在React中组件并不是真实的 DOM 节点,而是存在于内存之中的一种数据结构,叫做虚拟 DOM (virtual DOM)。只有当它插入文档以后,才会变成真实的 DOM 。根据 React 的设计,所有的 DOM 变动,都先在虚拟 DOM 上发生,然后再将实际发生变动的部分,反映在真实 DOM上,这种算法叫做 DOM diff ,它可以极大提高网页的性能表现。
上面代码中,组件 MyComponent 的子节点有一个文本输入框,用于获取用户的输入。这时就必须获取真实的 DOM 节点,虚拟 DOM 是拿不到用户输入的。为了做到这一点,文本输入框必须有一个 ref 属性,然后 this.refs.[refName] 就会返回这个真实的 DOM 节点。
通过这个ref我们同样可以获取input的输入值。就是这么简单。
但是使用过程中我们切记:由于 this.refs.[refName] 属性获取的是真实 DOM ,所以必须等到虚拟 DOM 插入文档以后,才能使用这个属性,否则会报错。上面代码中,通过为组件指定 Click 事件的回调函数,确保了只有等到真实 DOM 发生 Click 事件之后,才会读取 this.refs.[refName] 属性。
原文连接:http://blog.csdn.net/jiangbo_phd/article/details/51758148
在React中组件并不是真实的 DOM 节点,而是存在于内存之中的一种数据结构,叫做虚拟 DOM (virtual DOM)。只有当它插入文档以后,才会变成真实的 DOM 。根据 React 的设计,所有的 DOM 变动,都先在虚拟 DOM 上发生,然后再将实际发生变动的部分,反映在真实 DOM上,这种算法叫做 DOM diff ,它可以极大提高网页的性能表现。
var MyComponent = React.createClass({ handleClick: function() { this.refs.myTextInput.focus(); }, render: function() { return ( <div> <input type="text" ref="myTextInput" /> <input type="button" value="Focus the text input" onClick={this.handleClick} /> </div> ); } }); ReactDOM.render( <MyComponent />, document.getElementById('example') );
上面代码中,组件 MyComponent 的子节点有一个文本输入框,用于获取用户的输入。这时就必须获取真实的 DOM 节点,虚拟 DOM 是拿不到用户输入的。为了做到这一点,文本输入框必须有一个 ref 属性,然后 this.refs.[refName] 就会返回这个真实的 DOM 节点。
通过这个ref我们同样可以获取input的输入值。就是这么简单。
但是使用过程中我们切记:由于 this.refs.[refName] 属性获取的是真实 DOM ,所以必须等到虚拟 DOM 插入文档以后,才能使用这个属性,否则会报错。上面代码中,通过为组件指定 Click 事件的回调函数,确保了只有等到真实 DOM 发生 Click 事件之后,才会读取 this.refs.[refName] 属性。
原文连接:http://blog.csdn.net/jiangbo_phd/article/details/51758148
相关文章推荐
- ReactJS学习系列课程(React 动画使用)
- ReactJS学习系列课程(React ref的使用)
- ReactJS学习系列课程(React ref的使用)
- ReactJS学习系列课程(React Redux使用)
- ReactJS学习系列课程(JSX语法)
- ECMAScript 6 学习系列课程 (ES6 箭头函数的使用)
- NodeJS学习系列课程笔记(NodeJS util工具类相关使用方法)
- NodeJS学习系列课程笔记(NodeJs zlib库文件解压缩的相关使用方法)
- ReactJS学习系列课程(props 组件属性)
- ECMAScript 6 学习系列课程 (ES6 Symbol语法的使用)
- ECMAScript 6 学习系列课程 (ES6 默认值和解构赋值的使用)
- ECMAScript 6 学习系列课程 (ES6 Promise对象的使用)
- NodeJS学习系列课程笔记(NodeJS 全局对象相关使用方法)
- ReactJS学习系列课程(React 组件的组合使用)
- NodeJS学习系列课程笔记(NodeJs Buffer 的相关使用方法)
- ReactJS学习系列课程附加(Flux应用架构)
- ReactJS学习系列课程(React Router 使用)
- ReactJS学习系列课程(React webpack使用)
- ReactJS学习系列课程(React 整体流程使用案例)
- NodeJS学习系列课程笔记(NodeJs EventEmitter相关使用方法)