1.<SubSubComp {...this.props } /> 传递属性,{...props}的方式为组件传递了这两个属性,这就是JSX中的延展属性,"..."成为延展操作符,这种方式可以很方便地为组件指定多个属性  http://blog.csdn.net/yubo_725/article/details/50531817

2.mixin那里我真的没有看懂哈。

3.

<script type="text/jsx">
var FormApp = React.createClass({
  getInitialState:function(){
    return {
      inputValue: 'input value',
      selectValue: 'A',
      radioValue:'B',
      checkValues:[],
      textareaValue:'some text here,,,'
    }
},
  handleSubmit:function(e){
  e.preventDefault();
  var formData = {
  input: this.refs.goodInput.getDOMNode().value,
  select: this.refs.goodSelect.getDOMNode().value,
  textarea: this.refs.goodTextarea.getDOMNode().value,
  radio: this.state.radioValue,
  check: this.state.checkValues,
}
  console.log('the form result is:')
  console.log(formData);
  this.refs.goodRadio.saySomething();
},
  handleRadio:function(e){
    this.setState({
      radioValue: e.target.value,
  })
},
handleCheck:function(e){
  var checkValues = this.state.checkValues.slice();
  var newVal = e.target.value;
  var index = checkValues.indexOf(newVal);
  if( index == -1 ){
    checkValues.push( newVal )
  }else{
  checkValues.splice(index,1);
}
  this.setState({
    checkValues: checkValues,
  })
},
render: function(){
  return (
  <form onSubmit={this.handleSubmit}>
  <input ref="goodInput" type="text" defaultValue={this.state.inputValue }/>
  <!-- 这里的ref还可以这样写哈 function(comp){React.findDOMNode(comp).focus()} -->
  <br/>
  选项:
  <select defaultValue={ this.state.selectValue } ref="goodSelect">
  <option value="A">A</option>
  <option value="B">B</option>
  <option value="C">C</option>
  <option value="D">D</option>
  <option value="E">E</option>
  </select>
  <br/>
  <p>radio button!</p>
  <RadioButtons ref="goodRadio" handleRadio={this.handleRadio} />
  <br/>   <Checkboxes handleCheck={this.handleCheck} />
  <br/>
  <textarea defaultValue={this.state.textareaValue} ref="goodTextarea"></textarea>
  <button type="submit">提交</button>
</form>
)
}
}); var RadioButtons = React.createClass({
  saySomething:function(){
    alert("yo what's up man!");
  },
render:function(){
  return (
    <span>
    A
    <input onChange={this.props.handleRadio} name="goodRadio" type="radio" value="A"/>
    B
    <input onChange={this.props.handleRadio} name="goodRadio" type="radio" defaultChecked value="B"/>
    C
    <input onChange={this.props.handleRadio} name="goodRadio" type="radio" value="C"/>
    </span>
  )
  }
});
var Checkboxes = React.createClass({
    render: function(){
      return (
      <span>
      A
      <input onChange={this.props.handleCheck} name="goodCheckbox" type="checkbox" value="A"/>
      B
      <input onChange={this.props.handleCheck} name="goodCheckbox" type="checkbox" value="B" />
      C
      f<input onChange={this.props.handleCheck} name="goodCheckbox" type="checkbox" value="C" />
    </span>)
}
}) var formApp = React.render(
    <FormApp />,
    document.getElementById('app')
) </script>

4.minxins的双向数据绑定。

<script type="text/jsx">
var EasyForm = React.createClass({
mixins: [ React.addons.LinkedStateMixin ],
getInitialState:function(){
return {
message: 'react is awesome!',
isReactAwesome: true,
}
},
render:function(){
return (
<div>
<h1>我想说: {this.state.message}</h1>
<h2>React是不是很好用? {this.state.isReactAwesome?'非常好用!':'一般般。。。'}</h2>
<input type="text" valueLink={this.linkState('message')} />
<br/>
<input type="checkbox" checkedLink={this.linkState('isReactAwesome') } />
<br/>
<SubComp messageLink={ this.linkState('message') } likeLink={this.linkState('isReactAwesome')} /> </div>
)
}
}); var SubComp = React.createClass({
render:function(){
return (
<div>
<h3>这是个子组件哦</h3>
<SubSubComp {...this.props } />
</div>
)
}
}); var SubSubComp = React.createClass({
render:function(){
return (
<div>
<p>你想说什么?</p>
<input type="text" valueLink={ this.props.messageLink } />
<p>你稀罕React么?</p>
<input type="checkbox" checkedLink = {this.props.likeLink } />
</div>
)
}
}) React.render( <EasyForm />, document.getElementById('app') ); </script>

4.生命周期的函数:

getInitialState

getDefaultProps

componentWillMount

componentDidMount

componentWillUnmount

killMySelf

shouldComponentUpdate

componentWillUpdate

componentDidUpdate

doUpdate

react点滴的更多相关文章

  1. js的点滴

    一些好的博客 http://www.cnblogs.com/coding4/p/7809063.html canvas http://www.cnblogs.com/coding4/p/5593954 ...

  2. React Native实战系列教程之自定义原生UI组件和VideoView视频播放器开发

    React Native实战系列教程之自定义原生UI组件和VideoView视频播放器开发   2016/09/23 |  React Native技术文章 |  Sky丶清|  4 条评论 |  1 ...

  3. react组件的生命周期

    写在前面: 阅读了多遍文章之后,自己总结了一个.一遍加强记忆,和日后回顾. 一.实例化(初始化) var Button = React.createClass({ getInitialState: f ...

  4. 十分钟介绍mobx与react

    原文地址:https://mobxjs.github.io/mobx/getting-started.html 写在前面:本人英语水平有限,主要是写给自己看的,若有哪位同学看到了有问题的地方,请为我指 ...

  5. RxJS + Redux + React = Amazing!(译一)

    今天,我将Youtube上的<RxJS + Redux + React = Amazing!>翻译(+机译)了下来,以供国内的同学学习,英文听力好的同学可以直接看原版视频: https:/ ...

  6. React 入门教程

    React 起源于Facebook内部项目,是一个用来构建用户界面的 javascript 库,相当于MVC架构中的V层框架,与市面上其他框架不同的是,React 把每一个组件当成了一个状态机,组件内 ...

  7. 通往全栈工程师的捷径 —— react

    腾讯Bugly特约作者: 左明 首先,我们来看看 React 在世界范围的热度趋势,下图是关键词“房价”和 “React” 在 Google Trends 上的搜索量对比,蓝色的是 React,红色的 ...

  8. 2017-1-5 天气雨 React 学习笔记

    官方example 中basic-click-counter <script type="text/babel"> var Counter = React.create ...

  9. RxJS + Redux + React = Amazing!(译二)

    今天,我将Youtube上的<RxJS + Redux + React = Amazing!>的后半部分翻译(+机译)了下来,以供国内的同学学习,英文听力好的同学可以直接看原版视频: ht ...

随机推荐

  1. MySql数据库概念

    一.什么是数据库? 数据库(Database)是按照数据结构来组织.存储和管理数据的建立在计算机存储设备上的仓库. 简单来说是本身可视为电子化的文件柜——存储电子文件的处所,用户可以对文件中的数据进行 ...

  2. Win7的话,可能有十种简单的方法进行提速呢

    1.窗口转换更快速 Windows7绚丽的效果的确美观,但漂亮的效果就需要拿速度来交换,因此如果你想要Windows7中的各个窗口切换得更快速,那关闭窗口最大.最小化的动画效果后,你会发现窗口切换得更 ...

  3. 【RMAN】使用RMAN的 Compressed Backupsets备份压缩技术 (转载)

    1.Oracle参考文档中关于RMAN备份压缩的描述1)关于如何通过调整RMAN参数启用取消备份压缩功能http://download.oracle.com/docs/cd/B19306_01/bac ...

  4. py4CV例子2.5车牌识别和svm算法重构

    1.什easypr数据集:  ) ) ] all_label_list = temp[:, ] n_sample = , ) matcher = cv2.FlannBasedMatcher(flann ...

  5. log4j2的配置及使用

    log4j2与log4j1的不同点(不完整): 前者配置文件格式多样性.log4j2的配置文件可以是xml,也可以是json. 在不修改web.xml的前提下,前者配置文件的命名可以为log4j2.x ...

  6. UVALive 7501 Business Cycle(二分)题解

    题意:n个数,有一个起始值,按顺序从第一个开始不断循环取数,如果取完后相加小于0就变为0,最多取p个数,问你得到大于等于值g所需要的最小起始值为多少 思路:这题目爆long long爆的毫无准备,到处 ...

  7. powershell脚本的格式化

    Auto Formatting PowerShell in Visual Studio Code 1.安装visual studio code 2.安装powershell extension 3.打 ...

  8. R class of subset of matrix and data.frame

    a = matrix(     c(2, 4, 3, 1, 5, 7), # the data elements     nrow=2,              # number of rows   ...

  9. 不能安装64位office提示已安装32位的

    安装64位office办公软件的时候提示已经安装32位的office办公软件所以无法继续安装,但实际上之前安装的32位的office办公软件已经卸载了.问题现象截图如下: 从问题描述中,我们其实已经能 ...

  10. docker 安装redis

    https://blog.csdn.net/chenjianandiyi/article/details/78962709 运行镜像redis:  docker run --name redis1 - ...