分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 技术分享

ReactJS表单handleChange

发布时间:2023-09-06 01:34责任编辑:董明明关键词:React
 ???handleInputChange = (event) => { ???????const target = event.target; ???????const type = target.type; ???????const value = String.prototype.trim.call(target.value); ???????const name = target.name; ???????if (type === ‘checkbox‘) { ???????????if (this.state.formData[name] === undefined) { // 创建 ???????????????this.setState(() => ({ ???????????????????formData: Object.assign(this.state.formData, { ???????????????????????[name]: [value], ???????????????????}), ???????????????})); ???????????} else { ???????????????const valueIndex = this.state.formData[name].indexOf(value); ???????????????if (valueIndex < 0) { // 查找是否已经被勾选 ???????????????????this.setState((prevState) => ({ ???????????????????????formData: Object.defineProperty(this.state.formData, [name], { ???????????????????????????value: prevState.formData[name].concat([value]), ???????????????????????}), ???????????????????})); ???????????????} else { ???????????????????const arr = this.state.formData[name]; ???????????????????arr.splice(valueIndex, 1); // 去掉已经选择的 ???????????????????this.setState(() => ({ ???????????????????????formData: Object.defineProperty(this.state.formData, [name], { ???????????????????????????value: arr, ???????????????????????}), ???????????????????})); ???????????????} ???????????} ???????} else { ???????????this.setState(() => ({ ???????????????formData: Object.assign(this.state.formData, { ???????????????????[name]: value, ???????????????}), ???????????})); ???????} ???}

ReactJS表单handleChange

原文地址:https://www.cnblogs.com/biubiuxixiya/p/8206138.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved