4.3 开发一个自己的业务组件

优质
小牛编辑
143浏览
2023-12-01

一个标准的ES6 语法的组件

  • 每个组件都有一个 render 方法,用来接收数据然后返回要显示在页面上的内容。

如果你的项目中需要对常用业务组件进行封装,可以参考如下建议demo

开发一个自己的button

  • 新建 AwesomeProject/src/components/easy-button.jsx
/* @jsx createElement */
import { createElement, Component } from 'weex-rx';
import { mount } from 'nuke-mounter';
import { View, Text, TouchableHighlight, Modal} from 'nuke';

class EasyButton extends Component {
    pressHandler(e){
        Modal.toast('hello weex')
    }
    render() {
        const {style,onPress,children} = this.props;
        return(
            <TouchableHighlight onPress={this.pressHandler.bind(this)} style={style}>
                <Text>{children}</Text>
            </TouchableHighlight>);       
  }
}

export default EasyButton;

使用:

/* @jsx createElement */
import { createElement, Component } from 'weex-rx';
import { mount } from 'nuke-mounter';
import {EasyButton} from './components/easy-button.jsx';
import { View, Text, TouchableHighlight, Modal} from 'nuke';

class Demo extends Component{
    render(){
        return <View><EasyButton children='我是按钮'></EasyButton></View>
    }
}

mount(<Demo />, 'body');
  • TouchableHighlight

    在这个组件里,我们用到了基础组件 TouchableHighlight ,这个组件具备onPress 方法,而Text 组件没有onPress 方法。

  • Text

    Text 用于包裹一段文本。