JSX 的基本语法规则:遇到 HTML 标签(以 < 开头),就用 HTML 规则解析;遇到代码块(以 { 开头),就用 JavaScript 规则解析
组件类的第一个字母必须大写
组件类只能包含一个顶层标签
组件的属性可以在组件类的 this.props 对象上获取
class 属性需要写成 className ,for 属性需要写成 htmlFor
this.props.children 属性表示组件的所有子节点
this.props.children 的值有三种可能:如果当前组件没有子节点,它就是 undefined ;如果有一个子节点,数据类型是 object ;如果有多个子节点,数据类型就是 array
React 提供一个工具方法 React.Children 来处理 this.props.children 。我们可以用 React.Children.map 来遍历子节点
由于 this.refs.[refName] 属性获取的是真实 DOM ,所以必须等到虚拟 DOM 插入文档以后,才能使用这个属性,否则会报错
this.props 表示那些一旦定义,就不再改变的特性,而 this.state 是会随着用户互动而产生变化的特性
我们写一个XML标签,实质上就是在调用 React.createElement 这个方法,并返回一个 ReactElement 对象
渲染HTML标签,声明变量采用 首字母小写
渲染React组件,声明变量采用 首字母大写
当需要拓展我们的属性的时候,定义个一个属性对象,并通过 {…props} 的方式引入
属性值使用表达式,只要用 {} 替换 ""
在一个组件的子元素位置使用注释要用 {} 包起来
直接在标签上使用style属性时,要写成style={{}}是两个大括号
margin-top要写成marginTop
如果需要使用自定义属性,要加 data- 前缀
在编写JSX时,在 { } 中不能使用语句(if语句、for语句等等),但可以使用求值表达式
map遍历的时候,需要为每一条记录添加key
在ES6里,我们通过定义一个继承自React.Component的class来定义一个组件类
给组件定义方法不再用 名字: function()的写法,而是直接用名字(),在方法的最后也不能有逗号了
在ES6下,你需要通过bind来绑定this引用,或者使用箭头函数(它会绑定当前scope的this引用)来调用