有以下问题:
在asp.net/vb.net/ajax网站上工作是Visual Studio 2010,我试图在现有的文本框控件中使用HTML5 type="email"
来生成触摸屏设备的电子邮件目标键盘显示...
<asp:ToolkitScriptManager ID="ToolkitScriptManager1" runat="server">
</asp:ToolkitScriptManager>
<asp:UpdatePanel ID="UpdatePanel1" runat="server">
<ContentTemplate>
...
<asp:TextBox ID="Email" runat="server" CssClass="txtBox" type="email"></asp:TextBox>
<asp:Button ID="Confirmation" runat="server" Text="Confirm" CssClass="btnBox" OnClick="Confirmation_Click" OnClientClick="setFocus();" />
...
</ContentTemplate>
<Triggers>
<asp:AsyncPostBackTrigger ControlID="Confirmation" EventName="Click" />
</Triggers>
</asp:UpdatePanel>
但在代码隐藏中,Email.txt
返回一个空字符串。如果我删除type="email"
,一切都很好。
所以这引出了一个问题,我假设类型定义会覆盖文本框控件的隐含type="text"
,那么如何访问异步回发的控件值?或者我可以吗?
msg = String.Format("Email:{0} ", Email.Text)
更新
还尝试使用带有基本html元素的请求表单与Request.Form
一起使用,但在type="email"
...
<asp:TextBox ID="Email" name="Email" runat="server" CssClass="txtBox" type="email"></asp:TextBox><br />
<input id="Email1" name="Email1" type="email" CssClass="txtBox" />
...
代码隐藏
...
If Not Request.Form("Email1") Is Nothing Then
temp = Request.Form("Email1").ToString
End If
If Not Request.Form("Email") Is Nothing Then
temp = Request.Form("Email").ToString
End If
...
但如果我改变type="text"
,一切都很好......呃......
感谢任何指导...
戴夫
答案 0 :(得分:0)
呃......回答我自己的问题......
据说,"TextMode
&#34;在文本框控件中将支持Framework 4.5中的电子邮件等模式(未经过我测试),但此时我无法升级,因此有点创意并且可以解决问题。让我通过。
所以基本上我添加了一个隐藏的字段控件,并使用JavaScript将控件注入电子邮件字段中的值,这使我的代码能够使用值集...请参阅下面的代码。
<script type="text/javascript">
function setFocus() {
...
var hdnEmail = document.getElementById("HDNEmail");
var emlEmail = document.getElementById("Email1");
hdnEmail.value = emlEmail.value;
...
}
</script>
...
<input id="Email1" name="Email1" type="email" class="txtBox" />
<asp:HiddenField ID="HDNEmail" runat="server" ClientIDMode="Static"></asp:HiddenField>
...
<asp:Button ID="ctlBTNConfirmation" runat="server" Text="Confirm" CssClass="btnBox" OnClick="Confirmation_Click" OnClientClick="setFocus();" />
...
代码隐藏
...
temp = HDNEmail.Value
...
HTH某人,但如果其他人有更优雅的解决方案......请添加