使用单个事件处理程序来更改多个文本框值

时间:2018-06-25 06:12:17

标签: javascript reactjs optimization setstate spread-syntax

home.jsx文件

import React, { Component } from 'react';
// import 'react-dropdown/style.css';
import { Select, Input, Button } from 'antd';
import App from './App';


const { Option } = Select;
const INITIAL_STATE = {
    isShowResult: false,

    allData: {
        languages: [
            '/assets/tech logos/Languages/Javascript/angular js.png',
        ],

        frameWorks: [
            '/assets/tech logos/IDE/Eclipse.png',
        ],

        buildSystem: [
            '/assets/tech logos/Build servers/apache ant.png',
        ],

        bugTracking: [
            '/assets/tech logos/Bugtracking/bugzilla.png',
        ],

        textBox1: ' ',

        textBox2: ' ',

        textBox3: ' ',

        textBox4: ' ',
    },
};

export default class Home extends Component {
    constructor(props) {
        super(props);
        this.state = INITIAL_STATE;

        this.handleChangeLanguages = this.handleChangeLanguages.bind(this);
        this.handleChangeFrameworks = this.handleChangeFrameworks.bind(this);
        this.handleChangeBuildSystem = this.handleChangeBuildSystem.bind(this);
        this.handleChangeBugTracking = this.handleChangeBugTracking.bind(this);
        this.handleChangeTextBox = this.handleChangeTextBox.bind(this);
        this.handleChangeTextBox1 = this.handleChangeTextBox1.bind(this);
        this.handleChangeTextBox2 = this.handleChangeTextBox2.bind(this);
        this.handleChangeTextBox3 = this.handleChangeTextBox3.bind(this);
        this.handleSubmit = this.handleSubmit.bind(this);
    }

    handleChangeLanguages(languages) {
        this.setState({ languages });
    }

    handleChangeFrameworks(frameWorks) {
        this.setState({ frameWorks });
    }

    handleChangeBuildSystem(buildSystem) {
        this.setState({ buildSystem });
    }

    handleChangeBugTracking(bugTracking) {
        this.setState({ bugTracking });
    }

    handleChangeTextBox(e1) {
        this.setState(prevState => ({
            allData: {
                ...prevState.allData,
                textBox1: this.allData,
            },
        }));
        console.log(e1.target.value);
    }

    //  1st example

    // this.setState({
    //   e1: this.allData.text.value
    //   },()=> {
    //   console.log('Output: ' + this.state.content)
    //   })

    //  2nd example

    // this.setState(prevState => ({
    //   ...prevState,
    //   dragList: {
    //         ...prevState.dragList,
    //         [res]: {
    //               ...prevState.dragList[res],
    //               [type]: {
    //                     ...prevState.dragList[res][type],
    //                     ...result
    //               }
    //         }
    //   }
    // }))

    //  3rd example

    // ...this.state,
    //         textArea: {
    //           ...this.state.textArea,
    //           foo: foo,
    //         },
    //       }, ()=>console.log(this.state.textArea.foo)); //'some foo'
    //     }

    handleChangeTextBox1(e) {
        this.setState({
            allData: { ...this.prevState, ...this.e },
            ...this.textBox2 = e.target.value,
        });

        console.log(e.target.value);
    }

    handleChangeTextBox2(e) {
        this.setState({ allData: { textBox3: e.target.value } });
        console.log(e.target.value);
    }

    handleChangeTextBox3(e) {
        this.setState({ allData: { textBox4: e.target.value } });
        console.log(e.target.value);
    }

    handleSubmit(event) {
        // event.preventDefault();
        this.setState({ isShowResult: true });
    }


    render() {
        const { isShowResult, allData } = this.state;
        const {
            textBox1, textBox2, textBox3, textBox4,
        } = allData;
        return (
            <div>
                <div>
                    {!isShowResult &&
                        <form onSubmit={this.handleSubmit} style={{ padding: 30 }}>

                            { /* first dropdown */}

                            <div>
                                <b> <h3 > What language you like ? </h3> </b >

                            </div>
                            <Select mode="multiple" defaultValue="/assets/tech logos/Languages/Javascript/angular js.png" className="selectdiv" onChange={this.handleChangeLanguages}>
                                <Option value="/assets/tech logos/Languages/Javascript/angular js.png">
                                    <img src="/assets/tech logos/Languages/Javascript/angular js.png" alt="angular" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/JAVA/java-logo.jpg">
                                    <img src="/assets/tech logos/Languages/JAVA/java-logo.jpg" alt="java" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/Javascript/react js.png">
                                    <img src="/assets/tech logos/Languages/Javascript/react js.png" alt="reactjs" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/Javascript/node js.png">
                                    <img src="/assets/tech logos/Languages/Javascript/node js.png" alt="nodejs" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/Microsoft/AspDotNet.png">
                                    <img src="/assets/tech logos/Languages/Microsoft/AspDotNet.png" alt=".net" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/Python/Python.png">
                                    <img src="/assets/tech logos/Languages/Python/Python.png" alt="python" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/Languages/C++.png">
                                    <img src="/assets/tech logos/Languages/C++.png" alt="c++" className="image-size-slider" />
                                </Option>

                            </Select>

                            { /* second dropdown */}

                            <div >
                                <b > <h3 > Which STACK / IDE you like ? </h3></b >
                            </div>

                            <Select mode="multiple" defaultValue="/assets/tech logos/IDE/Eclipse.png" className="selectdiv" onChange={this.handleChangeFrameworks}>

                                <Option value="/assets/tech logos/IDE/Eclipse.png">
                                    <img src="/assets/tech logos/IDE/Eclipse.png" alt="eclipse" className="image-size-slider" />
                                </Option>

                                <Option value="/assets/tech logos/IDE/IntelliJ_IDEA_Logo.svg.png">
                                    <img src="/assets/tech logos/IDE/IntelliJ_IDEA_Logo.svg.png" alt="intellij" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/IDE/visual_studio_purple (1).png">
                                    <img src="/assets/tech logos/IDE/visual_studio_purple (1).png" alt="angular" className="image-size-slider" />
                                </Option>
                            </Select>

                            {/* third dropdown */}

                            <div>
                                <b> <h3>  Which Build Servers you like ? </h3> </b>
                            </div>
                            <Select mode="multiple" defaultValue="/assets/tech logos/Build servers/apache ant.png" style={{ padding: 10 }} onChange={this.handleChangeBuildSystem} >
                                <Option value="/assets/tech logos/Build servers/apache ant.png">
                                    <img src="/assets/tech logos/Build servers/apache ant.png" alt="apache" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/Build servers/bamboo-darkbluetext_medium_trans.png">
                                    <img src="/assets/tech logos/Build servers/bamboo-darkbluetext_medium_trans.png" alt="bamboo" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/Build servers/gitlab.png">
                                    <img src="/assets/tech logos/Build servers/gitlab.png" alt="gitlab" className="image-size-slider" />
                                </Option>
                                <Option value="assets/tech logos/Build servers/maven.png">
                                    <img src="/assets/tech logos/Build servers/maven.png" alt="maven" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/Build servers/vsts-2015.png">
                                    <img src="/assets/tech logos/Build servers/vsts-2015.png" alt="vsts" className="image-size-slider" />
                                </Option>

                            </Select>

                            {/* fourth dropdown */}

                            <div>
                                <b> <h3>  Which Bug Tracking Software you like ? </h3> </b>
                            </div>
                            <Select mode="multiple" defaultValue="/assets/tech logos/Bugtracking/bugzilla.png" style={{ padding: 10 }} onChange={this.handleChangeBugTracking} >
                                <Option value="/assets/tech logos/Bugtracking/bugzilla.png">
                                    <img src="/assets/tech logos/Bugtracking/bugzilla.png" alt="bugzilla" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/Bugtracking/jira.png">
                                    <img src="/assets/tech logos/Bugtracking/jira.png" alt="jira" className="image-size-slider" />
                                </Option>
                                <Option value="/assets/tech logos/Bugtracking/Micro focus ALM.jpeg">
                                    <img src="/assets/tech logos/Bugtracking/Micro focus ALM.jpeg" alt="focusAlm" className="image-size-slider" />
                                </Option>
                            </Select>
                            <div className="textarea example-input" >
                                <div>
                                    <b>
                                        <h3>
                                            Show me your interest.
                    </h3>
                                    </b>
                                    <Input size="large" value={textBox1} onChange={this.handleChangeTextBox} />
                                </div>
                                <div>
                                    <b>
                                        <h3>
                                            Show me your interest.
                    </h3>
                                    </b>
                                    <Input size="large" value={textBox2} onChange={this.handleChangeTextBox1} />
                                </div>
                                <div>
                                    <b>
                                        <h3>
                                            Show me your interest.
                    </h3>
                                    </b>
                                    <Input size="large" value={textBox3} onChange={this.handleChangeTextBox2} />
                                </div>
                                <div>
                                    <b>
                                        <h3>
                                            Show me your interest.
                    </h3>
                                    </b>
                                    <Input size="large" value={textBox4} onChange={this.handleChangeTextBox3} />
                                </div>
                            </div>
                            <div>
                                <Button type="danger" className="button" onClick={this.handleSubmit} >Click Here</Button>
                            </div>

                        </form>
                    }

                </div>

                <div>

                    {isShowResult &&
                        <div>
                            <App data={allData} />
                        </div>
                    }
                </div>
            </div>
        );
    }
}

app.js文件

import React from 'react';
import { Row, Col } from 'antd';
export const languages = [

    '/assets/tech logos/Languages/Javascript/angular js.png',
    '/assets/tech logos/Languages/JAVA/java-logo.jpg',
    '/assets/tech logos/Languages/Javascript/react js.png',
    '/assets/tech logos/Languages/Javascript/node js.png',
    '/assets/tech logos/Languages/Microsoft/AspDotNet.png',
    '/assets/tech logos/Languages/Python/Python.png',
    '/assets/tech logos/Languages/C++.png',

];

export const frameWorks = [
    '/assets/tech logos/IDE/Eclipse.png',
    '/assets/tech logos/IDE/IntelliJ_IDEA_Logo.svg.png',
    '/assets/tech logos/IDE/visual_studio_purple (1).png',
];

export const buildSystem = [
    '/assets/tech logos/Build servers/apache ant.png',
    '/assets/tech logos/Build servers/bamboo-darkbluetext_medium_trans.png',
    '/assets/tech logos/Build servers/gitlab.png',
    '/assets/tech logos/Build servers/maven.png',
    '/assets/tech logos/Build servers/vsts-2015.png',
];

export const bugTracking = [
    '/assets/tech logos/Bugtracking/bugzilla.png',
    '/assets/tech logos/Bugtracking/jira.png',
    '/assets/tech logos/Bugtracking/Micro focus ALM.jpeg',
];

export default function APP(props) {

    const languagesmap = props.data.map(languages => <img src={languages} alt={languages} className="image-size" />);
    const frameWorksmap = props.data1.map(frameWorks => <img src={frameWorks} alt={frameWorks} className="image-size" />);
    const buildSystemmap = props.data2.map(buildSystem => <img src={buildSystem} alt={buildSystem} className="image-size" />);
    const bugTrackingmap = props.data3.map(bugTracking => <img src={bugTracking} alt={bugTracking} className="image-size" />);

    return (
        <div>
            <center>
                <h1> <div className="text-color"> <b>MS SOFTWARE</b> </div> </h1>
                {/* <b>you selecte {props.data} </b> */}

            </center>
            <div className="gutter-example">

                <Row type="flex" justify="center" gutter={0}>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box border-right-upper">
                            <div>
                                <Row>

                                    <Col className="text" span={24}>
                                        <center>  <b> Tech Stack </b> </center>
                                    </Col>

                                </Row>

                                <Row>

                                    <Col span={24}>
                                        {/* <img src={languagesmap} alt={languagesmap} className="image-size"/> */}
                                        {languagesmap}
                                    </Col>

                                </Row>
                            </div>

                        </div>
                    </Col>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box border-right-upper">
                            <div>
                                <Row>

                                    <Col className="text" span={24}>

                                        <center>  <b> IDE/STACK </b> </center>

                                    </Col>

                                </Row>

                                <Row>

                                    <Col span={24}>
                                        {/* <img src={props.data1} alt={props.data1} className="image-size"/> */}
                                        {frameWorksmap}
                                    </Col>

                                </Row>

                            </div>

                        </div>
                    </Col>

                    <Col className="gutter-row" span={4}>
                        <div className="gutter-box border-right-upper">
                            <div>
                                <Row>

                                    <Col className="text" span={24}>

                                        <center>  <b> Build System </b> </center>
                                    </Col>

                                </Row>

                                <Row>
                                    <Col span={24}>
                                        {/* <img src={props.data2} alt={props.data2} className="image-size"/> */}
                                        {buildSystemmap}
                                    </Col>

                                </Row>
                            </div>
                        </div>
                    </Col>

                    <Col className="gutter-row" span={4}>
                        <div className="gutter-box border">
                            <div>
                                <Row>

                                    <Col className="text" span={24}>
                                        <center>  <b> Bug Tracking </b> </center>
                                    </Col>

                                </Row>

                                <Row>

                                    <Col span={24}>
                                        {/* <img src={props.data3} alt={props.data3} className="image-size"/> */}
                                        {bugTrackingmap}
                                    </Col>

                                </Row>
                            </div>
                        </div>
                    </Col>

                </Row>

                <Row type="flex" justify="center" gutter={0}>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box border-right-lower">
                            <Col span={4} />
                            <Col span={16}>
                                <b>
                                    {props.textData1}
                                </b>
                            </Col>
                            <Col span={4} />
                        </div>
                    </Col>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box border-right-lower">
                            <Col span={3} />
                            <Col span={18}>
                                <b>
                                    {props.textData2}
                                </b>
                            </Col>
                            <Col span={3} />
                        </div>
                    </Col>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box border-right-lower">
                            <Col span={4} />
                            <Col span={16}>
                                <b> {props.textData3} </b>
                            </Col>
                            <Col span={4} />
                        </div>
                    </Col>

                    <Col className="gutter-row " span={4}>
                        <div className="gutter-box">
                            <Col span={4} />
                            <Col span={16}>
                                <b> {props.textData4} </b>
                            </Col>
                            <Col span={4} />
                        </div>
                    </Col>

                </Row>

            </div>
        </div >
    );
}

如果我必须在setState函数中使用对象和散布运算符,应该怎么做:

handleChangeTextBox1(e){ 
      this.setState({
            allData:(this.state.textBox,{textBox:e.target.value} )
       }); 
 console.log(e.target.value) }

在这里,allData是具有对象textBox的函数。 textBox是用于数据输入的输入区域。我使用不同的句柄更改事件和this.setState的不同值来完成了此示例。如何在一个setState中使用它?

我尝试过的旧版本代码是:

handleChangeTextBox(e){ this.setState({allData:{textBox: e.target.value}}); console.log(e.target.value) }

但是这里一个文本框中的数据更改会更改所有句柄更改事件的数据。

3 个答案:

答案 0 :(得分:1)

您需要从状态识别文本到数据的映射,为此,您可以存储映射的值与textBox的ID

state = {
   allData: {}
}

handleChangeTextBox(e){
    this.setState(prevState => ({
        allData:{
          ...prevState.allData,
          [e.target.name]: e.target.value
        }
     })); 
}

此后,您可以将textBox值设置为

<input name="inp1" value={this.state.allData["inp1"]} onChange={this.handleChangeTextBox}/>

答案 1 :(得分:0)

尝试这样的事情

handleChangeTextBox1(e){ 
      this.setState((prevState)=>{
            return {allData:{...prevState.allData, {textBox:e.target.value}}}
       }); 
 console.log(e.target.value) 
}

答案 2 :(得分:0)

谢谢您的宝贵时间,但是经过这么长时间,我才有了方法。

`  handleChangeTextBox(e) {
    this.setState((prevState) => ({
      allData: {
        ...prevState.allData,
        textBox: e.target.value,
      }
    }));
    e.persist();
  }`

在这里,我使用了event.persist()方法,该方法将数据保持在异步模式中,并且用于数据的持久性如建议的名称一样,您可以在此处读取。 Event Persist in react

谢谢..;-)