React 入门(阮一峰教程笔记)

一 react.js react-dom.js Brower.js

  1. react.js 核心库
  2. react-dom.js提供dom方法
  3. Brower.js JSX语法--->JS语法
    服务器
    $ babel src --out-dir build //src内的js文件全部转换 放入build文件夹

二 ReactDOM.render()

ReactDOM.render(
  <h1>Hello, world!</h1>,
  document.getElementById('example')
);

三 JSX语法

  1. 支持js和html混写
var names = ['Alice', 'Emily', 'Kate'];

ReactDOM.render(
  <div>
  {
    names.map(function (name) {
      return <div>Hello, {name}!</div>
    })
  }
  </div>,
  document.getElementById('example')
);
  1. < 与 {
    JSX 与 数组
var arr = [
  <h1>Hello world!</h1>,
  <h2>React is awesome</h2>,
];
ReactDOM.render(
  <div>{arr}</div>,
  document.getElementById('example')
);

# 四 组件
```javascipt
var HelloMessage = React.createClass({
  render: function() {
    return <h1>Hello {this.props.name}</h1>;
  }
});

ReactDOM.render(
  <HelloMessage name="John" />,
  document.getElementById('example')
);

解释:

  1. 通过 React.createClass()方法构造组件类 HelloMessage,HelloMessage 是个类所以规范和类一样。组件类的第一个字母必须大写,否则会报错。
  2. 模版插入 <HelloMessage name="John" /> 的时候,就是在生成一个HelloMessage类的实例。
  3. 所有组件类必须拥有一个自己的render方法 用于输出组件。
  4. 组件类只能包含一个顶层标签
  5. 同原生HTML一样,组件可以加入自定义属性,如例子中的 name="John",然后通过组件类的this.props属性获取。
  6. 由于原生js的保留字,class属性要写成className for属性要写成htmlFor

五 this.props.children属性

this.props的属性和组件的属性基本是一一对应的,但是有一个例外就是this.props.children属性。它是在遍历组件的子节点

var NodeList = React.createClass({
  render: function() {
    return <ul>
          React.Children.map(this.props.children,(child)=>{
             return  <li>{child}</li>   //记住要return啊兄dei
})
    </ul>;
  }
});

ReactDOM.render(
  <NodeList>
      <span>john</span>
      <span>sam</span>
  </NodeList>
  document.getElementById('example')
);

解释:

  1. this.props.children的值有三种可能 :一个孩子节点:对象;多个孩子节点:数组;没有孩子节点:undefined
  2. React.Children是一个React提供的工具函数,用来处理this.props.children 而不用太关心子节点的类型(这个map方法的用法需要理解记一下)
  3. React.Children还有一些别的方法 ,官方手册

六 PropType

  1. 组件的属性可以接受字符串,数字,函数等任意类型,然而有时候我们想要规定组件能接受的类型,需要验证别人使用组件时的参数是否符合要求。
var MyTitle = React.createClass({
  propTypes: {
    title: React.PropTypes.string.isRequired //要求类型时string
  },

  render: function() {
     return <h1> {this.props.title} </h1>;
   }
});

var data = 123;

ReactDOM.render(
  <MyTitle title={data} />  //由于data是个数字不是要求的string类型 所以控制台会报错
  document.body

留下PropType的官方文档

  1. 可以通过getDefaultProps设置默认属性
var MyTitle = React.createClass({
  getDefaultProps : function () {
    return {
      title : 'Hello World'
    };
  },

  render: function() {
     return <h1> {this.props.title} </h1>;
   }
});

ReactDOM.render(
  <MyTitle />,
  document.body
);

七 获取真实的DOM节点

  1. diff算法:
    组件并不是真实的DOM节点,而是存在与内存中的一种数据结构,叫做虚拟DOM,只有当它真正插入文档中的时候才会真的变成DOM。
    React的设计时所有的DOM变动都现在虚拟的DOM上发生,然后再将实际变动的部分反映在真实的DOM上。这就是DOM diff 算法,它可以大大提升网页的性能表现。

  2. 如果想要拿到真实DOM,就要使用ref属性

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')
);
  1. 由于虚拟DOM是不能拿到用户的输入,所以如果要拿到输入,文本框必须要有一个ref属性(上例中:ref="myTextInput"),然后this.refs.[refName]就会返回真实的节点(上例子中:this.refs.myTextInput)
  2. 注意:由于this.refs.[refName]获取的是真实的DOM,所以一定要等到虚拟DOM插入文档之后才能使用这个属性,否则会报错,上例中通过为组件制定Click事件的回调函数,使得只有在真正的DOM被click(意味着虚拟DOM已经转换成了真实的DOM)之后,才读取this.refs.[refName]获得真实的DOM

this.state

将组件看成一个状态机,有一个初始状态,然后随着用户的交互状态发生改变而重新渲染UI。

var LikeButton = React.createClass({
  getInitialState: function() {
    return {liked: false};
  },
  handleClick: function(event) {
    this.setState({liked: !this.state.liked});
  },
  render: function() {
    var text = this.state.liked ? 'like' : 'haven\'t liked';
    return (
      <p onClick={this.handleClick}>
        You {text} this. Click to toggle.
      </p>
    );
  }
});

ReactDOM.render(
  <LikeButton />,
  document.getElementById('example')
);
  1. LikeButton组件类的getInitialState方法(这个方法是自带的)设置一个状态的初始值,就是一个对象(本例中{like:false}),这个对象可以通过this.state读取。render渲染出组件。用户点击导致状态变化,this.setState 方法就修改状态值,每次修改以后,自动调用 this.render 方法,再次渲染组件。
    由于 this.props 和 this.state 都用于描述组件的特性,可能会产生混淆。一个简单的区分方法是,this.props 表示那些一旦定义,就不再改变的特性,而 this.state 是会随着用户互动而产生变化的特性。

十 组件的生命周期

  1. 组件生命周期有三种:
    - Mounting: 已插入真实的DOM
    - Updating: 正在被重新渲染
    - Unmounting: 已移除真实DOM

  2. 每个状态都配有Will 和 Did相应的处理函数

    • componentWillMount()
    • componentDidMount()
    • componentWillUpdate(object nextProps, object nextState)
    • componentDidUpdate(object prevProps, object prevState)
    • componentWillUnmount()
  3. 两个特殊状态的处理函数

    • componentWillReceiveProps(object nextProps):已加载组件收到新的参数时调用
    • shouldComponentUpdate(object nextProps, object nextState):组件判断是否重新渲染时调用

参考文档

  1. 例子
var Hello = React.createClass({
  getInitialState: function () {
    return {
      opacity: 1.0
    };
  },

  componentDidMount: function () {
    this.timer = setInterval(function () {
      var opacity = this.state.opacity;
      opacity -= .05;
      if (opacity < 0.1) {
        opacity = 1.0;
      }
      this.setState({
        opacity: opacity
      });
    }.bind(this), 100);
  },

  render: function () {
    return (
      <div style={{opacity: this.state.opacity}}>
        Hello {this.props.name}
      </div>
    );
  }
});

ReactDOM.render(
  <Hello name="world"/>,
  document.body
);

上面代码在hello组件加载以后,通过 componentDidMount 方法设置一个定时器,每隔100毫秒,就重新设置组件的透明度,从而引发重新渲染
注意,内联样式

<div style={{opacity: this.state.opacity}}> //正确 外层大括号表示这是JS语法
<div style={opacity: this.state.opacity}> //错误

Ajax & Promise

采用Promise抓取github上面最高点赞的项目的例子是个很好的promise加React应用的例子。

var RepoList = React.createClass({
  getInitialState: function() {
    return { loading: true, error: null, data: null};
  },

  componentDidMount() {
    this.props.promise.then(
      value => this.setState({loading: false, data: value}),
      error => this.setState({loading: false, error: error}));
  },

  render: function() {
    if (this.state.loading) {
      return <span>Loading...</span>;
    }
    else if (this.state.error !== null) {
      return <span>Error: {this.state.error.message}</span>;
    }
    else {
      var repos = this.state.data.items;
      var repoList = repos.map(function (repo) {
        return (
          <li>
            <a href={repo.html_url}>{repo.name}</a> ({repo.stargazers_count} stars) <br/> {repo.description}
          </li>
        );
      });
      return (
        <main>
          <h1>Most Popular JavaScript Projects in Github</h1>
          <ol>{repoList}</ol>
        </main>
      );
    }
  }
});
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,904评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,581评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,527评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,463评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,546评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,572评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,582评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,330评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,776评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,087评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,257评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,923评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,571评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,192评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,436评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,145评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 2,818评论 0 24
  • 按照惯例,先给ReactJS背书 React是一个Facebook开发的UI库,于2013年5月开源,并迅速的从最...
    艾伦先生阅读 3,234评论 1 12
  • 作者:阮一峰原文地址:http://www.ruanyifeng.com/blog/2015/03/react.h...
    IT程序狮阅读 1,091评论 0 16
  • 2017.10.31 星期二 天气晴 今天一大早就接到妈妈的电话:祝我生日快乐,孩子的生日...
    馨逸馨诺妈妈阅读 226评论 0 0
  • 如果抬眼没能遇见温柔, 喝完这盏茶就走, 你是你,我还是我。 浅谈娇笑温开了壶中的水, 只...
    淘幺幺阅读 1,073评论 3 13