通用组件必须定义在 components
目录中,里面建一个文件夹与组件名
同名,下面 index.js
就是你编写组件的地方。
//components/Animal/index.js
import React from '@react';
class Animal extends React.Component { //组件名必须大写开头,与目录名一样
constructor(props) {
super();
this.state = {
name: props.name,
age: props.age || 1
};
}
static defaultProps = {
age: 1,
name: 'animal'
};
changeAge() {
this.setState({
age: ~~(Math.random() * 10)
});
}
componentDidMount() {
console.log('Animal componentDidMount');
}
componentWillReceiveProps(props) {
this.setState({
name: props.name
});
}
render() {
return (
<div style={{ border: '1px solid #333' }}>
名字:
{this.state.name} 年龄:
{this.state.age} 岁
<button catchTap={this.changeAge.bind(this)}>换一个年龄</button>
</div>
);
}
}
export default Animal;
由于目录可能比较深,因此 nanachi 比较贴心地提供了两个默认的别名,@react
与 @components
, @react
指向专门为小程序优化的 React, @components
指向开发目录下的 components
目录。
JSX 只能出现在 render()
方法或无状态组件的函数体中。
JSX 的所有填充数据必须带 this.props
, this.state
, this.context
前缀。
render()
方法里不能出现 var/const/let
语句,只能出现 if
语句与三元表达式或 JSX。
map()
方法调用的第一个参数最好使用匿名方法(因为这样会自动 bind this
),否则它会自动添加上第二个参数 this
<div class="group">
{this.state.iconSize.map(function(item) {
return <icon type="success" size={item} />;
})}
</div>
会变成
<div class="group">
{this.state.iconSize.map(function(item) {
return <icon type="success" size={item} />;
}, this)}
</div>
JSX 禁止出现 instanceUid
, classUid
, eventUid
, 这些是内部绑定事件时在编译阶段自动添加的。
render方法的第一个语句只能元素节点,不能是三元表达式或if语句等表示逻辑性的东西 错误的写法
class Dog extends React.Component{
//....略
render(){
return this.props.xxx ? <div>分支1</div>: <div>分支2</div>
}
}
正确的写法
class Dog extends React.Component{
//....略
render(){
return <div>{this.props.xxx ? <div>分支1</div>: <div>分支2</div>}</div>
}
}
原因是三元表达式会变成block标签,而快应用与自定义组件方式不支持顶层元素为template/block