Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

HTML5 email input cannot assign ID and RUNAT="Server" ASP.NET 4

Hi I am trying to assign an ID to an HTML5 input so that i can access its value from the code behind in the web form. However with the this code:

 <input type="email" required autofocus placeholder="Email Address" class="txt-input txt-input-username" ID="myTextBox" runat="server" />

Visual Studio 2010 is telling me that it cannot resolve the symbol ID="myTextBox".

Any ideas on how i can fix this because i have been searching for an answer for nearly a day? thanks

like image 930
adi bon Avatar asked Mar 21 '12 08:03

adi bon


2 Answers

Use this code to use HTML5 input type:

  1. Use this in .aspx file:

    <input type="text" required autofocus placeholder="Email Address"
        class="txt-input txt-input-username" ID="myTextBox" runat="server"/>
    
  2. Use this in .cs file:

     myTextBox.Attributes["type"] = "email";
    
like image 116
Sachin Gupta Avatar answered Nov 16 '22 00:11

Sachin Gupta


ASP.Net 4.0 HtmlGenericControl does not support the "Type" attribute as defined in your code, the error explains that, Parser Error Message: 'email' is not a valid type for an input tag., this is a arguably a "well known" or easily discovered bug in the ASP.Net framework.

There are several solutions that are outlined here:
http://msdn.microsoft.com/en-us/magazine/hh547102.aspxre
Update the framework and use the Asp.Net TextBox control Scott Hunter - HTML 5 Updates for .NET 4
Use a 3rd party ASP.Net Html5 UI control such as the one available from Codeplex.

A similar question is asked, and answered on the following SO posts:
How can I use HTML5 email input type with server-side .NET - This is the same issue as for the HtmlGenericControl however it is not addressed in the update
input types on server side controls


My personal preference ended up being to move to ASP.Net MVC 3, its quite a steep learning curve and a big change from the "Web Forms" style of ASP.Net web development however its soon forgotten once you get used to the symantics and coding styles.

like image 38
Lloyd Avatar answered Nov 16 '22 00:11

Lloyd