- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要一点帮助或建议如何让它工作 - 我有不止一组单选按钮第一组选中和取消选中并显示正确的输入,但是当我选中第二组时,第一组未选中并显示第二组的输入。当选中第二组单选按钮时,我希望第一组单选按钮不取消选中。奇怪的是,这两个名称组都不同,这不是为什么它取消选中以前的组。认为选中的控件在选中时可以更好地用于跟踪。可以帮助解决我的问题。
import React, { Component } from 'react';
import PropTypes from 'prop-types';
class MainForm extends Component {
constructor(props) {
super(props);
this.state = {
isChecked: null,
isHidden: true,
selectedOption: null,
checkedState: null,
};
}
handleCheckboxToggle(name, event) {
if (event.target.checked) {
this.setState({
checkedState: event.target.value,
isHidden: false,
selectedOption: event.target.name,
});
} else {
this.setState({
isHidden: true,
selectedOption: null,
});
}
}
renderCheckboxComponent(answer) {
return (
<div className="form__field--wrapper">
{
answer.map((item, index) => (
<div key={item.id} className="form__checkbox form__checkbox--inline">
<label className="form__checkbox required" htmlFor={`item.label-${item.name}-${index}`}>
{item.label}
</label>
<input
type="radio"
id={`item.label-${item.name}-${index}`}
name={item.name}
value={item.value}
onClick={e => this.handleCheckboxToggle(item.name, e)}
checked={this.state.checkedState === item.value}
/>
<span />
</div>
))
}
</div>
);
}
renderFieldInputComponent(fields, name) {
return (
<div>
{
fields.map(item => (
this.state.selectedOption === item.name ?
<div key={item.id} className="form__row">
<label className="required" htmlFor={name}>
{item.label}
</label>
<input
type={item.type}
id={name}
name={name}
required
placeholder={item.placeholder}
/>
<span />
</div> : ''
))
}
</div>
);
}
render() {
const { data } = this.props;
const { isHidden, isChecked } = this.state;
return (
<form>
{
data.map(item => (
<div key={item.id} className="form__row form__row--checkbox">
<p className="form__row--label">{item.name}</p>
{ this.renderCheckboxComponent(item.answer)}
{ !isHidden && this.renderFieldInputComponent(item.field, item.category)}
</div>
))
}
<button type="button" className="btn btn--red">Update Preferences</button>
</form>
);
}
}
MainForm.propTypes = {
data: PropTypes.arrayOf(PropTypes.shape({
id: PropTypes.number,
name: PropTypes.string,
}).isRequired).isRequired,
};
export default MainForm;
这是我正在处理的数据
{
"Questions":[
{
"id":1,
"name":"Email",
"category":"emailPermission",
"answer":[
{
"id":10,
"label":"Yes",
"value":"emailPermissionYes",
"name":"emailPermission",
"checked": true
},
{
"id":11,
"label":"No",
"value":"emailPermissionNo",
"name":"emailPermission",
"checked": true
}
],
"field":[
{
"id": 12,
"type": "email",
"name": "emailPermission",
"label": "Enter your email address",
"placeholder": "example@email.com",
"required": false
}
]
},
{
"id":2,
"name":"Post",
"category":"postPermission",
"answer":[
{
"id": 21,
"label":"Yes",
"value":"postPermissionYes",
"name":"postPermission",
"checked": true
},
{
"id": 22,
"label":"No",
"value":"postPermissionNo",
"name":"postPermission",
"checked": false
}
],
"field":[
{
"id": 23,
"type": "text",
"name": "postPermission",
"label": "Postcode",
"placeholder": "SE1 7TP",
"required": true
}
]
},
}
最佳答案
错误不在于您如何处理 name
,而在于您如何处理选中状态。
每当选中一个单选按钮时,this.state.checkedState
就会更改为当前选中的单选按钮的值。
这意味着当您选择问题 2 中的单选按钮时,您最终会得到类似于 {checkedState: 'postPermissionYes'}
的状态。
当 React 然后重新呈现所有复选框时,只有最近点击的复选框会通过 checked={this.state.checkedState === item.value}
测试。对于 checked={this.state.checkedState === item.value}
,之前点击的单选按钮将返回 false。
相反,我建议以稍微不同的方式处理 checkedState
……
将每个 radio 组的值存储到一个状态属性中,您可以为每个 radio 组使用 name
值。
这意味着您会将状态存储为:
this.state = {
emailPermission: null,
postPermission: null,
// other properties would go here as well...
}
您的处理程序如下所示:
handleCheckboxToggle(name, event) {
this.state[name] = event.target.value;
}
最后, radio 将确定 checked
属性如下:
checked={this.state[item.name] === item.value}
希望对您有所帮助!
关于javascript - 如何处理一组以上的单选按钮组 - reactjs,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50438144/
HTML 部分,只是我代码的一部分: HP: SP: EA: ED: PA: PD:
我有这个简单的脚本。我正在尝试获取选中的值并将它们添加到禁用输入框中的运行总计中。我知道它正在被选中,但它没有更新到输入框,我不确定为什么。谁能帮帮我? function updateF
我在使用自定义背景的单选按钮/复选框时遇到了问题。我在这里设计了它们的样式:Quick Tip: Easy CSS3 Checkboxes and Radio Buttons .主要部分是input在
我可以预见地读取 jQueryUI 单选按钮的值,但是,我无法以编程方式设置它。无论我使用哪种方法更改单选按钮的值,jQueryUI 界面都不会更新其界面。 Yes No
没有展开时 点击展开之后 <div class="flashread_item_box_time"> <span class="
这里是 JQuery 新手。 我有一个大约有 16 个字段的搜索表单,其中大部分是文本框。其余的都是下拉菜单。我在这些字段下方有 3 个单选按钮。当选择第一个时,表单中的某些字段应被禁用。当选择第二个
我目前正在构建一个 Fiori 应用程序用于查看事件(票证)。我必须创建一个饼图,其中包含票证的所有不同状态。当我单击图表的一部分时,它会将我带到包含该状态的所有票证的列表。我可以选择饼图的多个状态,
此代码将在使用 reloadData 刷新 UITableView 后恢复单元格选择: NSIndexPath *selectedIndexPath = [self.tableView indexPa
我正在尝试对 UITableView 单元格进行自定义选择。为此,我在我的单元格上方创建了 UIView,它现在在触摸时出现/消失。但问题是当我按下单元格选择时出现。如果那时我选择任何其他行,它也会被
我所有的复选框、单选框和文本输入都在 ID 的末尾附加了“_boom”。我想抓取这些 id 的页面,检测更改以查看其中是否有任何一个与其原始状态不同,如果是,则将 CSS 应用于页面上名为“保存”的按
我正在寻找一种方法,使多选列表框应显示为普通的单选组合框,但在单击时它应作为允许多选的列表框,如下所示,如电子表格中所示。我正在寻找 CSS HTML 和 javascript 而非 Jquery 中
我有一个 HTML 我想显示为“列表框”(一个同时显示多个元素的框,而不是下拉框)。但是,我只想允许选择一个元素。我还想将盒子的高度(通过 CSS)设置为其容器大小的 100%。 这三件事似乎是相互排
我有一个包含三个部分的付款表格。基本上,第一个是带有乘数的“单选”列表,第二个是带有设置值的“复选框”列表,第三个是带有乘数的下拉列表 ==> (jsfiddle) .为清楚起见,我插入了一个文本框来
我想删除单选按钮,只显示是或否标签。为此,我隐藏了 radio 输入并使用 css3 选择器 (:checked + label) 根据选择更改背景颜色。但由于某种原因,这不起作用。 HTML(来自
我正在使用这个插件http://www.erichynds.com/examples/jquery-ui-multiselect-widget/demos/#single对于多选,并且希望也可以在同一
我收到了这段代码,但我似乎无法正常工作,我查看了之前的问题,但找不到任何与之完全相同的代码。也许这完全是错误的,应该重新开始? 我想要做的是在选择单选按钮时显示一个 div。这是我的代码: jQue
我试图在用户点击输入(单选、复选框或选择)时移除焦点背景,但它不起作用。这些是我放在元素上的样式: .form-holder input[type="radio"]:focus, .form-
我正在使用 Bootstrap 4 并想使用单选按钮和复选框按钮组,但按钮显示的是实际的单选按钮和复选框 UI 元素,如下所示: 上面的例子直接摘自文档。我试过删除并重新安装 Bootstrap 4,
我正在使用 Collection View 进行水平滚动。它工作得很好。现在我想为选择任何单元格设置任何效果。所以,我写了这段代码” func collectionView(collectionVi
我有一个按钮组,其中包含必须充当单选按钮的几个项目。我还需要将它们分成几行并跨越容器的整个宽度。 为此,我使用了 Bootstrap 的类 btn-group-justified ,然后我拆分 元素分
我是一名优秀的程序员,十分优秀!