React基础(一)

NO.1 ReactDom.render

ReactDom.render是React最基本的用法,用于将模板转化为HTML语言,并插入指定的DOM节点。

ReactDom.render(
  ,
  document.getElementById('app')
  );

上面代码的含义是将Name这个组件插入ID为app的元素中。

NO.2 JSX语法

将HTML语言直接写入带JS语言之中,这就是JSX语法

var names = ['Alice', 'Emily', 'Kate'];
ReactDOM.render(
  
{ names.map(function (name) { return
Hello, {name}!
}) }
, document.getElementById('example') );

JSX的语法规则是如果遇到HTML的标签,就用HTML的规则解析,如果遇到代码块,就用JS的规则解析。

JSX允许直接在模板中插入JS变量,如果变量是一个数组,则会展开这个数组的所有成员查看

var arr = [
    

Hello world!

,

React is awesome

, ]; ReactDOM.render(
{arr}
, document.getElementById('example') );

NO.3 组件(component)

新建一个name.js,把他封装成为一个组件,内容如下:

'use strict';
import React from "react";
class Name extends React.Component {
render () {
  return (
    
hello~
); } } export { Name as default };

Name就是一个组件类,模板插入,会自动生成Name的一个实例,有三点必须注意:
1.所有组件中必须有自己的render方法,用于输出组件;
2.组件类的第一个字母必须大写,否则会报错;
3.组件只能包含一个顶层标签,否则会报错;例如,如果将return里面的内容改成:

  return (
    
hello~
youngi~
);

然后webpack会返回报错信息:
Adjacent JSX elements must be wrapped in an enclosing tag (11:4)

组件的用法和原生的HTML的用法一致,可以加入任意属性,比如,有一点值得注意的是,class和for这两个属性应该写为className和htmlFor

ReactDom.render(
  ,
  document.getElementById('app')
  );

那么在组件中,想要获取这个属性就可以用this.props.name读取:

class Name extends React.Component {
render () {
  return (
    
hello~
{this.props.name}
); } }

NO.4 this.props.children

这个是个特例,这个代表的意思不是去找this.props的children属性,而是去找这个组件的所有子节点

这里需要注意, this.props.children 的值有三种可能:如果当前组件没有子节点,它就是 undefined ;如果有一个子节点,数据类型是 object ;如果有多个子节点,数据类型就是 array 。所以,处理 this.props.children 的时候要小心。

React 提供一个工具方法 React.Children 来处理 this.props.children 。我们可以用 React.Children.map 来遍历子节点,而不用担心 this.props.children 的数据类型是 undefined 还是 object。

render: function() {
    return (
      
    { React.Children.map(this.props.children, function (child) { return
  1. {child}
  2. ; }) }
); }

NO.5 PropTypes

这个属性是组件类的属性,而不是组件的属性,这个PropTypes可以用来验证从组件传来的属性是否合法。例如:

import React from 'react';
import ReactDom from 'react-dom';
import Name from './name';

var name = 123

ReactDom.render(
  ,
  document.getElementById('app')
  );

如上代码显示,Name组件的name属性的类型为number类型,而不是字符串,那么在组件类中,对这个属性进行验证:

class Name extends React.Component {
render () {
  return (
    
hello~
{this.props.name}
); } } Name.propTypes = { name: React.PropTypes.string.isRequired };

进行验证后,验证不通过的话,会在控制台上报错

Invalid prop `name` of type `number` supplied to `Name`, expected `string`.

NO.6 defaultProps 设置组件的默认值

class Name extends React.Component {
render () {
  return (
    
hello~
{this.props.name}
); } } Name.defaultProps = { name: "youngi" };

你可能感兴趣的:(React基础(一))