radio-button 相关问题

单选按钮是表单中使用的元素。它们让用户只选择有限数量的选项中的一个。

如何更改悬停时选中的单选按钮的颜色?

<!-- This is my html input tag --> <input class="custom-radio" type="radio" name="selected_center" value="{{center.id}}" id="selected_center_{{center.id}}"> <!-- Only CSS I am using for my custom color using accent property but cant change the color on hover --> input[type='radio'] { accent-color: #0098ff; } 我已将悬停属性与输入单选标签一起使用,但不起作用。 不确定您为什么要这样做,但您可以做到。 body { margin: 1em; font-family: sans-serif; } .custom-radio>label { display: block; font-size: 1.5em; margin: 0.25em 0; } .custom-radio>label>input[type=radio] { transform: scale(2); vertical-align: middle; margin-right: 1em; } .custom-radio>label:nth-child(1)>input[type=radio] { accent-color: red; } .custom-radio>label:nth-child(2)>input[type=radio] { accent-color: darkorange; } .custom-radio>label:nth-child(3)>input[type=radio] { accent-color: green; } .custom-radio>label:hover { color: blue; } .custom-radio>label:hover>input[type=radio] { accent-color: blue; } .custom-radio>label>input[type=radio]:not(:checked) { cursor: pointer; } <div class="custom-radio"> <label><input type="radio" name="radio1"> Stop</label> <label><input type="radio" name="radio1"> Wait</label> <label><input type="radio" name="radio1"> Go</label> </div>

回答 1 投票 0

如何在编辑表单中设置单选按钮选定的值

我正在使用 ReactiveFormModule 创建编辑表单。我想在编辑表单中显示数据,例如文本框、下拉列表、单选框和复选框。我可以使用 setValue 成功设置文本框和下拉列表的值

回答 1 投票 0

如何在两个单选按钮之间切换,并且在reactjs中单击它时应该打开一个单独的组件

我正在创建一个登录页面,它有两个不同的组件,分别名为管理员登录和客户登录,它们在登录表单中显示为单选按钮,如果我单击客户登录单选按钮,它应该...

回答 1 投票 0

AngularJS 取消选中单选按钮

我尝试使用 ng-dblclick、$event 等寻找其他解决方案,但它们似乎都不适合我。 我在表格中的 ng-repeat 内有两个单选按钮。我有一个字段用于 s...

回答 2 投票 0

React - 基于单选按钮选择动态更新 UI

问题 我正在开发一个网络应用程序功能,可以计算特定区域的隔热系数。您可以在此处查看实时 Codesandbox 示例(这是带有

回答 1 投票 0

Android 自定义视图,其行为类似于 RadioButton/CheckBox

我有以下自定义视图 有 2 个文本字段和一个 RadioButton,我希望它的行为像 RadioButton(当涉及到对讲时) 现在: 当选择 customRadioButton 时,它说

回答 1 投票 0

在 Drupal Webforms YAML 中有条件地预选单选按钮

我正在尝试有条件地预选 Drupal Webforms 中的单选按钮(我认为这必须使用 YAML 来完成?)。 我有一个隐藏字段“ref”,它可以有 4 个值中的 1 个(de、fr、it、en)。

回答 1 投票 0

Python - 我的 CTkRadioButtons 接受多个选择

我对三个单选按钮有一个问题,它们接受一次性选择所有按钮。我该如何防止这种事情,当我按下另一个按钮时,选择会返回...

回答 1 投票 0

单选按钮选中香草js时显示div

这里有点挣扎。我的事件侦听器仅检测到单选按钮的“已选中”更改,而不是“未选中”更改。注意:仅纯 javascript (vanillajs),无 jQuery。 一点 JSFiddle

回答 2 投票 0

根据先前的组禁用单选按钮组

我有 2 组 2 个单选按钮。除非在第 1 组中选择“是”,否则应禁用第 2 组。但是,如果用户从“是”切换,则需要清除并禁用第二组

回答 1 投票 0

动态加载数据时,如何为 Angular 中的数组分配默认值?

我有一个名为“习惯”的数组。像这样 我将其显示在带有单选按钮的表格中(是,否)。 我有一个名为“习惯”的数组。像这样 我将其显示在带有单选按钮的表格中(是,否)。 <tr *ngFor="let habits of masterDate.data.habits; index as x"> <th class="tbl-border-right-bottom text-wrap" style="width: 50%"> {{ habits.name }} <div hidden="true"> <input type="text" formControlName="habitsSufferedMainId{{ x }}" /> </div> </th> <td class="tbl-border-right-bottom"> <div class="col-md-6"> <div class="form-group d-flex justify-content-around pr-2"> <div class="custom-control custom-radio"> <input type="radio" class="custom-control-input" id="habitsSufferedMain{{ x }}" value="1" name="habitsSufferedMain{{ x }}" formControlName="habitsSufferedMain{{ x }}" /> <label class="custom-control-label" for="habitsSufferedMain{{ x }}">Yes</label> </div> <div class="custom-control custom-radio"> <input type="radio" class="custom-control-input" id="isMainHabitNo{{ x }}" value="0" name="habitsSufferedMain{{ x }}" formControlName="habitsSufferedMain{{ x }}" [checked]="true" /> <label class="custom-control-label" for="isMainHabitNo{{ x }}">No</label> </div> </div> </div> <div class="form-group"> <textarea placeholder="If 'Yes' please give details" class="form-control form-control-sm" rows="2" formControlName="habitsSufferedMainReason{{ x }}"></textarea> </div> </td> </tr> 如何将默认值设置为“否”。 根据点击是或否,将值放入数组中。 首先创建一个地图来存储结果 const results = new Map<number, boolean>(); 您可以使用 FormControl() 设置复选框的默认值 const habitOne = new FormControl(false); results['habitOne'].set(false); 然后监听 valueChanges oberbable 将结果存储在 Map 中 habitOne.valueChanges.subscribe(value => { results.set('habitOne', value) }) 当然,您可以使用 FormBuilder 通过循环来完成此操作。 (但请记住以反应形式包装所有输入<form [formGroup]=form> form: FormGroup; constructor(private fb: FormBuilder) { this.form = this.fb.group( this.habits.reduce((controls, habit, index) => { this.results.set(index, false) return { ...controls, [`habit${index}`]: new FormControl(false) } }, {})); Object.keys(this.form.controls).forEach((control, index) => { control.valueChanges.subscribe(value => { this.results.set(index, value == true) }) } }

回答 1 投票 0

防止单选按钮下方的文本换行

我能描述我想要的最好的方式就是用这张图片: 如何使文本与顶部文本对齐,而不是与单选按钮对齐? 相关CSS如下: .basic-灰色{ 宽...

回答 5 投票 0

如何取消选中单选按钮

我有两种表单,一种带有单选按钮,用户必须选择该按钮才能编辑。 [表格名称=“A”] [输入类型=“无线电”名称=“BookItem”值=“1”/] [输入类型=“无线电”名称=“” 我有两种表单,一种带有单选按钮,用户必须选择该按钮才能编辑。 [form name="A"] <li>[input type="radio" name="BookItem" value="1" /]</li> <li>[input type="radio" name="BookItem" value="2" /]</li> <li>[input type="radio" name="BookItem" value="3" /]</li> [form]<p> 从表单 (A) 中选择“BookItem”后,我调用 $("#EditFormWrapper").load("callEditData.cfm? ID="+ID); 函数来加载第二个表单 (B) <div id="EditFormWrapper"><div></p> <!---// begin dynamic form generated by external file callEditData.cfm //---> [form id="editForm" name="B"] <ul class="hourswrapper"> <li><input type="checkbox" id="TOR2Hours" class="TOR2Hours" name="TOR2Hours" value="AM2Hrs1" /> 2 Hours AM</li> <li><input type="checkbox" id="TOR2Hours" class="TOR2Hours" name="TOR2Hours" value="PM2Hrs1" /> 2 Hours PM</li> <li><input type="checkbox" id="TOR2Hours" class="TOR2Hours" name="TOR2Hours" value="AM2Hrs2" /> 2 Hours AM</li> <li><input type="checkbox" id="TOR2Hours" class="TOR2Hours" name="TOR2Hours" value="PM2Hrs2" /> 2 Hours PM</li> </ul> [input type="image" src="images/submit-btn.gif" id="addBTN" name="addBTN" class="buttons" alt="SubmitRrequest" /] [input type="image" src="images/cancel-btn.gif" id="editBTNcancel" name="editBTNcancel" class="buttons" alt="Cancel Request" /] [/form] <!---// end dynamic form from external file //---> 当用户单击表单(B)中的取消按钮(editBTNcancel)时,我想取消选中表单(A)上的单选按钮。 这是我的脚本: $("#editBTNcancel").live("click", function(event){ event.preventDefault(); $("#EditFormWrapper").slideUp("fast").empty(); //$('.TOR2Hours').removeAttr('checked'); $('.TOR2Hours').attr('checked', false); }); 我希望我清楚地说明我的问题,任何建议将不胜感激! 您可以像这样访问表格... var exampleForm = document.forms['form_name']; 然后循环遍历表格 for( var i=0; i<exampleForm.length; i++ ){ alert( exampleForm[i].type ); } 你可以像这样测试检查... if( exampleForm[i].checked ) 要取消选择选中的单选按钮,请尝试... exampleForm[i].checked=false; 最终的代码看起来像这样...... var exampleForm = document.forms['form_name']; for( var i=0; i<exampleForm.length; i++ ){ if( exampleForm[i].type ) == 'radio' && exampleForm[i].checked == true ){ exampleForm[i].checked = false; } } 我不确定你到底想要什么,但你可以尝试使用重置输入。 <input type='reset' /> 由于这几乎是最简单的 DOM 任务并且适用于每个可编写脚本的浏览器,因此我建议不要使用 jQuery 方法: $(".TOR2Hours")[0].checked = false; 我想到的另一件事是你的选择器是否正确。您的意思是按类选择一组元素还是应该使用 ID 选择器? 您的选择器根本就是错误的。 如果您想取消选中第一个表单中的单选按钮,您应该使用 $('input[name="BookItem"]') 而不是 $('.TOR2Hours') : $("#editBTNcancel").on("click", function(event){ $("#EditFormWrapper").slideUp("fast").empty(); $('input[name="BookItem"]').attr('checked', false); }); 至于使用哪种方法取消选中单选按钮,以下 3 种方法应该都有效: $('input[name="BookItem"]').attr('checked', false); $('input[name="BookItem"]').removeAttr('checked'); $('input[name="BookItem"]').prop('checked', false); 但是,请查看关于 jQuery prop() 的 jQuery 文档,了解 attr() 和 prop() 之间的区别。 我刚刚发现了这个问题的一个很好的解决方案。 假设您有两个无线电需要能够选中/取消选中,请实现此代码并更改必要的内容: var gift_click = 0; function HandleGiftClick() { if (document.getElementById('LeftPanelContent_giftDeed2').checked == true) { gift_click++; memorial_click = 0; } if (gift_click % 2 == 0) {document.getElementById('LeftPanelContent_giftDeed2').checked = false; } } var memorial_click = 0; function HandleMemorialClick() { if (document.getElementById('LeftPanelContent_memorialDeed2').checked == true) { memorial_click++; gift_click = 0; } if (memorial_click % 2 == 0) { document.getElementById('LeftPanelContent_memorialDeed2').checked = false; } } :)不客气 我用这种方式解决了你在ASP.net中的问题,检查这个.. radioButton.InputAttributes["show"] = "false"; string clickJs = " if(this.show =='true'){this.show ='false'; this.checked = false;}else{this.show='true'; this.checked = true;};"; radioButton.Attributes["onClick"] = clickJs; 在asp.net中,可以使用这种方式添加属性。您还可以手动向radioButton添加属性,并执行函数(clickJs)来更改ckecked属性!!! Array.prototype.forEach.call(auswahl_dachaufbau, function(rd) { // Event-Listener für Radio-Buttons rd.addEventListener("mousedown", function(e) { let id = e.target.id; if (this.checked) { reset_dachaufbau(id); // Das Setzen der onclick-function auf diese Weise ist dafür da, damit man // Radio-Buttons auch unchecked machen kann ohne einen neuen Radio-Button auszuwählen // Seltsamerweise ist das nicht möglich ohne weiteres this.onclick = function() { this.checked = false; } } else { this.onclick = null; select_dachaufbau(id); } }); }); Funktioniert 沉浸式

回答 7 投票 0

我的两个单选按钮在相同的 HTML 代码下表现不同

在下面的代码中,当我单击男性文本(不是单选按钮)时,它会选择该选项,但是当我单击女性文本时,它会选择单选按钮。如何?请帮忙。 ` 在下面的代码中,当我单击男性文本(不是单选按钮)时,它会选择该选项,但是当我单击女性文本时,它会选择单选按钮。如何?请帮忙。 `<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> </head> <body> <form action="action.php"> <lable for="id1"> <input type="radio" value="Male" name="Gender" id="id1">Male </lable> <label for="id2"> <input type="radio" value="Female" name="Gender" id="id2">Female </label> </form> </body> </html>` 我期望通过单击男性文本来选择男性单选按钮,但只有在单击男性单选按钮后才会选择它。 问题是两个单选按钮具有相同的名称属性。 <lable for="Male"> <input type="radio" value="Male" name="Male" id="id1">Male </lable> <label for="Female"> <input type="radio" value="Female" name="Female" id="id2">Female </label>

回答 1 投票 0

Next/React.js 中页面重新加载后,默认选定的单选按钮消失

通过路由器链接(从“next/link”作为链接导入)导航到页面时,默认选择工作正常。但是,当页面重新加载时,默认选择的选项会立即出现...

回答 1 投票 0

如何在 MUI 单选按钮中添加勾号图标而不是项目符号图标

我需要从'@mui/icons-material/CheckCircleSharp'添加CheckCircleSharpIcon而不是项目符号图标 {res?.map((radiooption, 索引) => ( <> 我需要从'@mui/icons-material/CheckCircleSharp'添加CheckCircleSharpIcon而不是项目符号图标 {res?.map((radiooption, index) => ( <> <RadioGroup aria-labelledby="demo-radio-buttons-group-label" name="radio-buttons-group" className={classes.radioGroup} value={value} onChange={handleChange} key={radiooption.secondaryRadioName} > <FormControlLabel className={classes.radioButton} value= {radiooption?.secondaryRadioName} control={<Radio />} label={<span dangerouslySetInnerHTML={{ __html: radiooption?.secondaryRadioName }}/>} /> </RadioGroup> </> ))} 根据 API,您可以利用其 checkedIcon 属性,因此 Radio 组件应该如下所示 <Radio checkedIcon={<CheckCircleIcon />} /> 链接到checkedIcon道具信息:https://mui.com/material-ui/api/radio/#Radio-prop-checkedIcon CodeSandbox 工作演示:https://codesandbox.io/s/bold-cloud-xhylt5?file=/Demo.tsx:718-761

回答 1 投票 0

多个单选按钮组均可在同一次单击上切换

在我的角度应用程序中,我只是尝试创建多个单选按钮组。一个组看起来像这样: 在我的角度应用程序中,我只是尝试创建多个单选按钮组。一组看起来像这样: <input [formControl]="ctrlx" type="radio" [value]="true" id="idx" autocomplete="off"/> <label for="idx">Yes</label> <input [formControl]="ctrlx" type="radio" [value]="false" id="idy" autocomplete="off" /> <label for="idy">No</label> 演示 奇怪的是,正如您在演示中看到的那样,当您单击其中一个收音机时,其他所有收音机也会发生变化。不知何故,我的无线电组已连接。有什么建议我在这里做错了吗? 只需给每个组一个唯一的名称 <div> <input [formControl]="ctrlx" type="radio" [value]="true" id="idx" name="a" autocomplete="off"/> <label for="idx">Yes</label> <input [formControl]="ctrlx" type="radio" [value]="false" id="idy" name="a" autocomplete="off" /> <label for="idy">No</label> </div>

回答 1 投票 0

将状态设置为单选按钮标签的值

我有一个表单中的单选按钮列表。 所需品种(如果有) ... 我有一个表单中的单选按钮列表。 <h6>Desired breed (if any)</h6> <div className="radio container-fluid"> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Goldendoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">English Goldendoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Labradoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Poodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Other</p> </label> <label> <input type="radio" className="checkbox" name="Breed" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">No preference</p> </label> </div> </label> </div> 我想做的是将 Breed 变量设置为所选复选框的值。问题是我得到的值是 on,而不是标签上的内容。 我无法更改单选按钮的名称属性,因为我一次只需要选择一个。 (我也愿意接受其他方法来实现这一目标)。 尝试像这样改变onClick: onClick={(e) => setBreed(e.target.nextSibling.textContent)} <input type="radio" />元素没有任何值,这就是使用"on"的原因。当为每个 value 提供 <input /> 属性时,您可以看到状态正确更新。 这还允许您将实际值与显示的标签分开。例如,假设您的界面有多种语言版本。在这种情况下,您将为每种语言使用不同的标签,但值将保持不变。 function App() { const [breed, setBreed] = React.useState(null); console.log(breed); return ( <div> <h6>Desired breed (if any)</h6> <div className="radio container-fluid"> <label> <input type="radio" className="checkbox" name="Breed" value="Goldendoodle" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Goldendoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" value="English Goldendoodle" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">English Goldendoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" value="Labradoodle" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Labradoodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" value="Poodle" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Poodle</p> </label> <label> <input type="radio" className="checkbox" name="Breed" value="Other" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">Other</p> </label> <label> <input type="radio" className="checkbox" name="Breed" value="No preference" onClick={(e) => setBreed(e.target.value)} /> <p className="checkbox">No preference</p> </label> </div> </div> ); } ReactDOM.render(<App />, document.querySelector("#root")); <script crossorigin src="https://unpkg.com/react@17/umd/react.production.min.js"></script> <script crossorigin src="https://unpkg.com/react-dom@17/umd/react-dom.production.min.js"></script> <div id="root"></div>

回答 2 投票 0

我无法在输入类型上动态分配值:radio / Angular

我很迷失,我正在尝试根据网址动态构建表单的模板,但由于某种原因我无法在单选类型输入上设置属性值。 表单蛋糕 html 我很迷失,我正在尝试根据网址动态构建表单的模板,但由于某种原因我无法在单选类型输入上设置属性值。 form-cake html <form [formGroup]="formCake" (ngSubmit)="onSubmit()"> <ng-container *ngFor="let template of formTemplate"> <label for="{{template.id}}">{{template.label}}: </label> <input id="{{template.id}}" type="{{template.type}}" [name]="template.name" [formControlName]="template.name" [attr.value]="(template.type === 'radio') ? template.value: null"> </ng-container> 形成蛋糕组件 ngOnInit(): void { this.formCake = this.formService.formControllerSetup(); this.formTemplate = this.formService.formHtmlSetup(); 表单服务 formControllerSetup(): FormGroup { return this.fb.group({ name: ['', Validators.required], description: ['', [Validators.required]], image: ['', Validators.required], price: [+'', Validators.required], cakeType: [null, Validators.required], allergies: this.fb.group({ cereal: [false], nuts: [false], eggs: [false], milk: [false], soy: [false], peanuts: [false], sulfite: [false], // ... Ajoute d'autres allergies ici }) }); } formHtmlSetup() { let fields!: any[]; return fields = [ { type: 'text',id: 'name',name: 'name', label: 'Name', validation: { required: true } }, { type: 'text',id: 'description', name: 'description', label: 'Description', validation: { required: true } }, { type: 'text',id: 'image', name: 'image', label: 'Image', validation: { required: true } }, { type: 'number',id: 'price', name: 'price', label: 'Price', validation: { required: true } }, { type: 'radio',id: 'pm', name: 'cakeType', label: 'Pm', validation: { required: true } }, { type: 'radio',id: 'pie', name: 'cakeType', label: 'Pie', validation: { required: true } }, ] } 我正在服务内构建模板,将其注入到组件内,然后在 formTemplate 上循环以获取 HTML 中的所有字段。 <input id="{{template.id}}" type="{{template.type}}" [name]="template.name" [formControlName]="template.name" [attr.value]="template.id"> 我确实尝试过 [value]="template.id"/ value="{{template.id}}" 但只有这个版本可以工作[attr.value]="template.id"。知道原来有一个三元 [attr.value]="(template.type === 'radio') ? template.id: null" 过滤其他字段。 但是像这样,我可以看到其他输入正在更新,但无线电类型没有更新。 也许我累了,但不知道该往哪里看。 恐怕您无法使用 FormControlName 将类型单选和值动态分配给输入。我认为你唯一能做到的就是使用两个 *ngIf (一个用于输入类型无线电,另一个用于其余) <form [formGroup]="formCake"> <ng-container *ngFor="let template of formTemplate"> <label for="{{template.id}}">{{template.label}}: </label> <input *ngIf="template.type==='radio'" [id]="template.id" type="radio" [name]="'_'+template.name" [value]="template.type == 'radio' ? template.id: null" [formControlName]="template.name" /> <input *ngIf="template.type!=='radio'" id="{{template.id}}" [type]="template.type" [name]="'_'+template.name" [value]="template.type == 'radio' ? template.id: null" [formControlName]="template.name" /> </ng-container> </form>

回答 1 投票 0

在jsp中获取表格动态选定行的值

我在jsp中有一个页面,其中我在表中动态显示数据库中的记录,并生成动态行。每行都有一个单选按钮,以便用户可以选择...

回答 1 投票 0

© www.soinside.com 2019 - 2024. All rights reserved.