首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >问答首页 >如何在单击复选框时将一个输入框复制到另一个输入框

如何在单击复选框时将一个输入框复制到另一个输入框
EN

Stack Overflow用户
提问于 2020-04-06 21:34:31
回答 1查看 221关注 0票数 0

我正在尝试使用reactjs将一个输入框值复制到另一个输入框,单击checkbox。

这是我关于如何将输入值复制到另一个输入的代码。

代码语言:javascript
代码运行次数:0
运行
复制
import React from "react";
import "./styles.css";

export default class App extends React.Component {
  constructor() {
    super(props);
    this.state = {
      BillingAddress: "",
      ShippingAddress: "",
      copybilling: false
    };
  }
  changeDetails = e => {
    const { name, value, checked, maxLength } = e.target;
    const { Details, formErrors } = this.state;
    let formObj = {};
    if (name === "copybilling") {
      // handle the change event of language field
      if (checked) {
        // push selected value in list
        formObj = {
          ...Details,
          [name]: true
        };
        this.setState({
          ShippingAddress: this.state.Details.BillingAddress
        });
      } else {
        // remove unchecked value from the list
        formObj = {
          ...Details,
          [name]: false
        };
      }
    } else {
      // handle change event except language field
      formObj = {
        ...Details,
        [name]: value
      };
    }
  };

  render() {
    return (
      <>
        <textarea
          name="BillingAddress"
          value={this.state.BillingAddress}
          onChange={this.changeDetails}
        />
        <textarea
          name="ShippingAddress"
          value={this.state.ShippingAddress}
          onChange={this.changeDetails}
        />
      </>
    );
  }
}
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-04-07 12:58:05

我希望这能有所帮助。

代码语言:javascript
代码运行次数:0
运行
复制
class App extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      BillingAddress: "",
      ShippingAddress: "",
      copybilling: false
    };
  }

  changeDetails = e => {
    const { name, value, checked, maxLength } = e.target;
    const { Details, formErrors } = this.state;
    let formObj = {};
    if (name === "copybilling") {
      // handle the change event of language field
      if (checked) {
        // push selected value in list
        this.setState({
          [name]: true,
          ShippingAddress: this.state.BillingAddress
        });
      } else {
        // remove unchecked value from the list
        this.setState({
          [name]: false,
          ShippingAddress: ''
        });
      }
    } else {
      // handle change event except language field
      this.setState({
        [name]: value
      });
    }
  };

  render() {
    return (
      <div>
        <textarea
          name="BillingAddress"
          value={this.state.BillingAddress}
          onChange={this.changeDetails}
        />
        <textarea
          name="ShippingAddress"
          value={this.state.ShippingAddress}
          onChange={this.changeDetails}
        />
        Copy :
        <input
          type="checkbox"
          name="copybilling"
          checked={this.state.copybilling}
          onChange={this.changeDetails}
        />
      </div>
    );
  }
}

ReactDOM.render(<App />, document.getElementById('root'));
代码语言:javascript
代码运行次数:0
运行
复制
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="root"></div>

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/61061091

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档