0

在 Stack Overflow 和其他地方还有许多其他问题,但我花了太多时间筛选它们以获得答案,最终我自己没有问。我已经尝试了许多在这里找到的解决方案,但没有一个有效。

我的问题如标题所述;我的单选按钮没有在页面加载时设置,我不知道为什么。

在下面的代码中,我的模型有一个布尔值 CanSubmit,canSubmitYes 和 canSubmitNo id 是使用生成的 id

ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldId("canSubmitYes")

ViewContext.ViewData.TemplateInfo.GetFullHtmlFieldId("canSubmitNo")

我的单选按钮和相应的标签当前设置如下:

@Html.LabelFor(Function(m) m.CanSubmit, "Yes", New With {.for = canSubmitYes})
@Html.RadioButtonFor(Function(m) m.CanSubmit, True, New With {.id = canSubmitYes, .class = "submit-toggle-yes"})

@Html.LabelFor(Function(m) m.CanSubmit, "No", New With {.for = canSubmitNo})
@Html.RadioButtonFor(Function(m) m.CanSubmit, False, New With {.id = canSubmitNo, .class = "submit-toggle-no"})

我试过的:

  • checked="checked"在 helpers HTMLAttributes 集合中设置属性
  • 去掉所有的 HTMLHelper 代码,简单地使用基本<input type="radio" />控件,由于某种原因,它仍然没有在加载时被正确检查。
  • 尝试使用 jQuery 事件在加载文档时设置它们的“已检查”属性,这也不起作用。(通过.prop("checked", true)
  • 将我的 html 助手格式从"false"更改false为尝试强制它理解该属性是布尔值而不是字符串

这些控件没有其他 javascript 事件设置值。当我观察到我单击按钮时,对象上的 HTML 值没有发生变化——这让我认为“clicked”/“checked”属性是伪属性或浏览器持有的状态。

我错过了一些重要的事情还是我在这里偏离了基地?

提前致谢!

更新

我已经确定它与我正在使用的局部变量有关。我现在<input>再次将它们放在 basic 中,如果我不连接它们,它们会按预期工作。只有当我尝试将它们与一个共同name的(将它们联系在一起的方式)配对时,它们才不起作用。

<input name="radio@(Model.ID)" id="@canSubmitYes" type="radio" class="submit-toggle-yes" @(If(submitterPermission.IsSelected, "checked='checked'", "")) />
<label for="@canSubmitYes">Yes</label>

<input name="radio@(Model.ID)" id="@canSubmitNo" type="radio" class="submit-toggle-no" @(If(submitterPermission.IsSelected, "", "checked='checked'")) />
<label for="@canSubmitNo">No</label>

如果我删除该name=''属性,那么它会在加载时正确检查正确的元素。我需要这些项目是独一无二的,因为页面上可能有 50 多个这样的配对。

4

1 回答 1

0

我刚刚发现我没有回答这个问题。

我们最终没有发现问题,但最终采用了不同的方法。此外,我不再从事该项目,因此我无法充分更新此问题。

于 2016-07-26T18:15:47.020 回答