WebX - Ext Plugin

增强 web 式开发体验的插件。

样式增强

注意,通过 WebX 的方式写样式无需调用 StyleSheet.create() 方法。

样式名的定义

支持 class 属性

// jsx
<View class="item item-gap" />

// styles
styles = {
    item: {},
    'item-gap': {},
};

支持组件名定义样式

// jsx
<View />

// styles
styles = {
    View: {},
}

支持 vhvw 单位

// jsx
<Text class="test" />

// styles
styles = {
    test: {
        fontSize: '3vh',
        width: '50vw',
    }
};

支持 :active

自身 :active

// jsx
<Text class="test" />

// styles
styles = {
    test: {
        ':active': {}
    }
};

其他组件 :active

通过获取其他组件的 :active 改变自己样式。

// jsx
<View class="outer">
    <Text class="inner" />
</View>

// styles
styles = {
    inner: {
        'outer:active': {
            color: 'red',
        }
    }
};

上例中,outer 激活时,inner 字体颜色变为红色。

注意:当前组件和其他组件直接没有层级约束(不是父子元素也行)。

支持媒体查询(宽高)

只支持宽高的媒体查询。

外部媒体查询

// jsx
<Text class="test" />

// styles
styles = {
    '@media (min-width: 400)': {
        test: {}
    },
};

内部媒体查询

// jsx
<Text class="test" />

// styles
styles = {
    test: {
        '@media (min-height: 500)': {
            color: 'red'
        },
        '@media (max-height:900) and (min-height: 500)': {
            color: 'blue'
        },
    },
};

方法增强

支持 view 的 onPress 属性

// jsx
<View onPress={this.testPressView} />

// js
testPressView() {
    alert('You pressed a View.');
}

组件方法自动 .bind(this)

on 开头的方法,无需手动 .bind(this)

// jsx
<TouchableHighlight onPress={this.testAutoBind} />

// js
testAutoBind() {
    console.log('testAutoBind', this);
}