แชร์ผ่าน


ASP.NET - Form tag doesn’t have “name” attribute - xhtmlConformance

I was recently working on an issue that one of my customers was facing on his website. He had an ASP.NET website that he has migrated from ASP.NET 1.1 to ASP.NET 4.0. They were running few javascript where they try to change a textbox value, accessing it via the form like below:

window.opener.document.form1.textbox1.value = “hello world!”

They saw this statement fail, and doesn’t update the value. While debugging this (via IE’s supercool developer tools F12), found that the “form1” specified is undefined. We are sure that there is a form in the page1 that opened this page2. If we look at the HTML output sent by the server, we saw the below:

<form method=”post” id=”form1”> </form>

Oh yes, the form exists, but not with a name attribute. That’s what is picked if you access it as document.form1. You simply don’t have any element in the DOM with name “form1”, and that’s why your javascript was failing. Till here, everything is clear in white. Now, where was the problem?

Issue started for them where the same code was working on one server, and the same was failing in other server. I manually compared the code, and there is absolutely no difference between the servers. Both the websites run in ASP.NET 4.0. But, yes – there got to be something different between the servers right?

It was found to be with the web.config files, I never got access to their web.config files earlier, so I couldn’t do a simple diff on them to find something has changed. Rather, thought about few things which would be causing the addition of “name” attribute in the <form> tag. And, it was xhtmlConformance tag set the mode to “Legacy” on one server, and not set on the other one (failing one). So what this setting really do? Take a look at this article which briefs a few things on XHTML standards, and ASP.NET.

The name attribute on the form element is not allowed in XHTML 1.1 guidelines. You can configure your application not to render a name attribute.

ASP.NET 4.0 by default doesn’t create the name attribute for the form element, and that created the problem to this project my customer was working on. We generally do not recommend setting the xhtmlConformance mode as "Legacy", since it would not force the server tags to be standards compliance. Although it can work well with your websites, you can consider changing it to “Strict” or “Transitional” as per the requirement. You can read more about this setting in this blog of ScottGu.

So, if you set it to “Strict” or “Transitional”, your javascripts will fail since it will look for the form with its name. But, in this scenario, you could use the getElementById() function to grab the element that you are interested in.