我似乎无法解决这个问题,或者找到有关此问题的任何信息。我正在使用.html()函数生成动态HTML,以单选按钮格式列出相机选择。 创建html的代码正常工作AFAIK:
var showcameras = function()
{
var html = "<fieldset data-role='controlgroup' data-type='horizontal'>";
for (var i = 0; i < sessiondetails["Camera-Count"]; i++)
{
var name;
var namelabel = "Camera-Names_" + i;
var idlabel = "Camera-ID_" + i;
if (sessiondetails[namelabel]==="")
name = "Camera " + (i+1);
else
name = sessiondetails[namelabel];
html += "<input type='radio' name='"+name+"' id='"+sessiondetails[idlabel]+"' value='"+sessiondetails[idlabel]+"'>";
html += "<label for='"+sessiondetails[idlabel]+"'>"+name+"</label>";
}
html += "</fieldset>";
window.$("#camselection").html(html).trigger("create");
};
这是它创建的HTML:
<fieldset data-role='controlgroup' data-type='horizontal'>
<input type='radio' name='test1' id='10000' value='10000'>
<label for='10000'>test1</label>
<input type='radio' name='Camera 2' id='10001' value='10001'>
<label for='10001'>Camera 2</label>
<input type='radio' name='Camera 3' id='10002' value='10002'>
<label for='10002'>Camera 3</label>
<input type='radio' name='Camera 4' id='10003' value='10003'>
<label for='10003'>Camera 4</label>
</fieldset>
这是“camselection”div标签的HTML:
<div id="camselection" data-role="fieldcontain"></div>
问题是,我一次可以选择多个单选按钮。对我来说没有意义,因为他们在同一个字段集中。我甚至尝试在每个按钮上放置onClick('refresh'),但它不起作用。非常感谢任何帮助!
答案 0 :(得分:6)
为了只选择一个单选按钮,它们必须具有相同的名称。
<fieldset data-role='controlgroup' data-type='horizontal'>
<input type='radio' name='camera' id='c10000' value='10000'>
<label for='c10000'>test1</label>
<input type='radio' name='camera' id='c10001' value='10001'>
<label for='c10001'>Camera 2</label>
<input type='radio' name='camera' id='c10002' value='10002'>
<label for='c10002'>Camera 3</label>
<input type='radio' name='camera' id='c10003' value='10003'>
<label for='c10003'>Camera 4</label>
</fieldset>
BTW,当id
属性以字母开头时,它会更好。
答案 1 :(得分:1)
http://www.w3schools.com/html/html_forms.asp
单选按钮分组由名称属性定义。您的按钮都有不同的名称,因此它们是不同组的一部分。
它应该是这样的:
<fieldset data-role='controlgroup' data-type='horizontal'>
<input type='radio' name='camera' id='10000' value='10000'>
<label for='10000'>test1</label>
<input type='radio' name='camera' id='10001' value='10001'>
<label for='10001'>Camera 2</label>
<input type='radio' name='camera' id='10002' value='10002'>
<label for='10002'>Camera 3</label>
<input type='radio' name='camera' id='10003' value='10003'>
<label for='10003'>Camera 4</label>
</fieldset>
答案 2 :(得分:1)
尝试给单选按钮指定相同的名称。然后,您将只能选择一个单选按钮。