Chinaunix首页 | 论坛 | 博客
  • 博客访问: 86184
  • 博文数量: 52
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 540
  • 用 户 组: 普通用户
  • 注册时间: 2019-05-29 11:52
文章分类
文章存档

2019年(52)

我的朋友

分类: JavaScript

2019-06-11 16:20:56

React免费课程:阿里云大学——开发者课堂

在实例中我们设置了输入框 input value = {this.state.data}。在输入框值发生变化时我们可以更新 state。我们可以使用onChange 事件来监听 input 的变化,并修改 state

React 实例


  1. var HelloMessage = React.createClass({

  2.   getInitialState: function() {

  3.     return {value: 'Hello edu.aliyun.com!'};

  4.   }, handleChange: function(event) {

  5.     this.setState({value: event.target.value});

  6.     },

  7.       render: function() {

  8.     var value = this.state.value;

  9.     return <div>

  10.             <input type="text" value={value} onChange={this.handleChange} />

  11.             <h4>{value}</h4>

  12.            </div>

  13.     ;

  14.       }});ReactDOM.render(

  15.   <HelloMessage />

  16.       ,

  17.       document.getElementById('example')

  18. );

  19. Hello edu.aliyun.


上面的代码将渲染出一个值为 Hello Openketang! input 元素,并通过 onChange 事件响应更新用户输入的值。

实例 2

在以下实例中我们将为大家演示如何在子组件上使用表单。 onChange 方法将触发 state 的更新并将更新的值传递到子组件的输入框的 value 上来重新渲染界面。

你需要在父组件通过创建事件句柄 (handleChange) ,并作为 prop (updateStateProp) 传递到你的子组件上。


  1. var Content = React.createClass({

  2.   render: function() {

  3.     return <div>

  4.             <input type="text" value={this.props.myDataProp} onChange={this.props.updateStateProp} />

  5.             <h4>{this.props.myDataProp}</h4>

  6.             </div>; }});var HelloMessage = React.createClass({

  7.   getInitialState: function() {

  8.     return {value: 'Hello edu.aliyun.com!'};

  9.   },

  10.     handleChange: function(event) {

  11.     this.setState({value: event.target.value});

  12.       },

  13.       render: function() {

  14.     var value = this.state.value;

  15.           return <div>

  16.             <Content myDataProp = {value}

  17.               updateStateProp = {this.handleChange}></Content>

  18.            </div>;

  19.             }});

  20.             ReactDOM.render(

  21.   <HelloMessage />,

  22.             document.getElementById('example')

  23. );


运行结果


  1. Hello edu.aliyun.


React 事件

以下实例演示通过 onClick 事件来修改数据:


  1. var HelloMessage = React.createClass({

  2.   getInitialState: function() {

  3.     return {value: 'edu.aliyun.com!'};

  4.   },

  5.     handleChange: function(event) {

  6.     this.setState({value: '阿里云大学'})

  7.   },

  8.       render: function() {

  9.     var value = this.state.value;

  10.           return <div>

  11.             <button onClick={this.handleChange}>点我</button>

  12.             <h4>{value}</h4>

  13.            </div>;

  14.             }});

  15.             ReactDOM.render(

  16.   <HelloMessage />,

  17.       document.getElementById('example')


  18. );


运行结果


  1. 点我

  2. Hello edu.aliyun.


当你需要从子组件中更新父组件的 state 时,你需要在父组件通过创建事件句柄 (handleChange) ,并作为 prop (updateStateProp) 传递到你的子组件上。实例如下:


  1. var Content = React.createClass({
  2.   render: function() {
  3.     return <div>
  4.               <button onClick = {this.props.updateStateProp}>点我</button>
  5.               <h4>{this.props.myDataProp}</h4>
  6.            </div> }});var HelloMessage = React.createClass({
  7.   getInitialState: function() {
  8.     return {value: 'Hello edu.aliyun.com!'}; }, handleChange: function(event) {
  9.     this.setState({value: '阿里云大学'})
  10.   }, render: function() {
  11.     var value = this.state.value;
  12.     return <div>
  13.             <Content myDataProp = {value}
  14.               updateStateProp = {this.handleChange}>
  15.     </Content>
  16.            </div>
  17.     ;
  18.      }});
  19.      ReactDOM.render(
  20.   <HelloMessage />, document.getElementById('example')
  21. );


运行结果


  1. 点我

  2. Hello edu.aliyun.


React免费课程:

阅读(477) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~