zoukankan      html  css  js  c++  java
  • [RN] React Native 实现 多选标签

     React Native 实现 多选标签

    效果如下:

     

    实现代码:

    import React, {Component} from 'react';
    import {Button, StyleSheet, Text, TouchableOpacity, View} from 'react-native';
    
    export default class TestMarkCheck extends Component {
        static defaultProps = {
            multiList: [
                {
                    "id": "0",
                    "name": "音乐",
                    select: false
                },
                {
                    "id": "1",
                    "name": "美术",
                    select: false
                },
                {
                    "id": "2",
                    "name": "舞蹈",
                    select: false
                },
            ]
        };
    
        constructor(props) {
            super(props);
            this.state = {
                multiData: this.props.multiList,
                selectMultiItem: [],
            }
        }
    
        _selectMultiItemPress(item) {
            if (item.select) {
                this.state.selectMultiItem.splice(this.state.selectMultiItem.findIndex(function (x) {
                    return x === item.id;
                }), 1);
            } else {
                this.state.selectMultiItem.push(item.id);
            }
            this.state.multiData[item.id].select = !item.select;
            this.setState({multiData: this.state.multiData});
        }
    
        _submitMultiPress() {
            alert(`选中了${JSON.stringify(this.state.selectMultiItem)}`)
        }
    
        _renderMultiMark() {
            let multiData = this.state.multiData;
            let len = multiData.length;
            let menuArr = [];
            for (let i = 0; i < len; i++) {
                let item = multiData[i];
                if (item.select) {
                    menuArr.push(
                        <TouchableOpacity
                            onPress={() => this._selectMultiItemPress(item)} style={[styles.markRow, styles.markChecked]}>
                            <Text style={styles.markCheckedText}>{item.name}</Text>
                        </TouchableOpacity>
                    )
                } else {
                    menuArr.push(
                        <TouchableOpacity
                            onPress={() => this._selectMultiItemPress(item)} style={[styles.markRow, styles.markUnCheck]}>
                            <Text style={styles.markUnCheckText}>{item.name}</Text>
                        </TouchableOpacity>
                    )
                }
            }
            return (
                <View style={styles.multiBox}>
                    {menuArr}
                </View>
            );
        }
    
        render() {
    
            return (
                <View style={styles.container}>
                    {this._renderMultiMark()}
    
                    <Button title={"确定"} onPress={() => this._submitMultiPress()}/>
    
                </View>
            );
    
        }
    }
    const styles = StyleSheet.create({
        container: {
            flex: 1,
            backgroundColor: "white",
        },
        multiBox: {
            flexDirection: 'row',
            alignItems: 'center',
            marginTop: 20,
            marginBottom: 20,
            paddingLeft: 20,
            paddingRight: 20,
        },
        markRow: {
             90,
            height: 40,
            lineHeight: 40,
            padding: 10,
            marginBottom: 16,
            marginRight: 16,
            borderRadius: 24,
            borderWidth: 0.5,
        },
        markChecked: {
            backgroundColor: "#aaa",
            borderColor: "white",
        },
        markUnCheck: {
            backgroundColor: "white",
            borderColor: "#111",
        },
        markCheckedText: {
            fontSize: 15,
            color: "white",
            textAlign: "center",
        },
        markUnCheckText: {
            fontSize: 15,
            color: "#000",
            textAlign: "center",
        },
    });

    成功企业家,五大基本能力:

    产品 营销 团队 资本 财务

    本博客地址: wukong1688

    本文原文地址:https://www.cnblogs.com/wukong1688/p/11062409.html

    转载请著名出处!谢谢~~

  • 相关阅读:
    asp.net生命周期
    中国互联网公司数据库访问现状
    console在文件中
    2011程序员薪资调查报告全文发布
    Centos上搭建能用于ok6410开发板的tftp服务器
    Centos 上搭建nfs且可挂载到6410开发板
    linux下软件的卸载与安装
    基于ok6410的韦东山驱动视频简要分析lcd驱动
    6410上移植uboot
    编译可加载触摸屏驱动的uImage内核。
  • 原文地址:https://www.cnblogs.com/wukong1688/p/11087661.html
Copyright © 2011-2022 走看看