Вот как я создаю свой флажок:
HtmlInputCheckBox checkbox = new HtmlInputCheckBox();
checkbox.ID = _Data.ControlID;
checkbox.Attributes.Add("class", "checkbox");
checkbox.Attributes.Add("autocomplete", "off");
sReplacementString = element.RenderToString();
RenderToString
— это расширение, которое делает следующее:
public static string RenderToString(this Control control)
{
StringBuilder sb = new StringBuilder();
using (StringWriter writer = new StringWriter(sb))
{
using (HtmlTextWriter htmlWriter = new HtmlTextWriter(writer))
{
control.RenderControl(htmlWriter);
}
}
return sb.ToString();
}
Это создает строку с закрывающим тегом на input, я вижу это при отладке
<input name="ttWBF_1" type="checkbox" id="ttWBF_1" autocomplete="off" class="checkbox" />
Затем он добавляется в HTML с помощью пакета Agility Pack как такового:
HtmlNode temp = doc.CreateElement("temp");
temp.InnerHtml = sReplacementString;
HtmlNode current = inputNode;
foreach (HtmlNode child in temp.ChildNodes)
{
inputNode.ParentNode.InsertAfter(child, current);
current = child;
}
inputNode.ParentNode.RemoveChild(inputNode);
Однако в HTML в теге input для флажка отсутствует самозакрывающаяся косая черта, и поэтому он не проходит проверку WC3.
<input name="ttWBF_1" type="checkbox" id="ttWBF_1" autocomplete="off" class="checkbox">
Это происходит с моими текстовыми полями, которые генерируются таким же образом. Похоже, они теряются при добавлении HTML на страницу с помощью гибкого пакета.
Как мне предотвратить это?