ASP.NET Javascript Textbox onblur

ASP.NET Javascript Textbox onblur

本文关键字:onblur Textbox Javascript NET ASP      更新时间:2023-09-26

我在页面上注册javascript时遇到了一些问题,这样我的文本框就可以在onBlur上启动它。我创建了一个简单的测试页面来演示我的问题。

这是后端VB.Net

Public Class Test
Inherits System.Web.UI.Page
Protected Sub Page_Load(ByVal sender As Object, ByVal e As System.EventArgs)
    Dim scriptText As String = ""
    scriptText &= "<script language='javascript'>"
    scriptText &= "function DisplayBlurMessage(){alert('you clicked outside the textbox');}"
    scriptText &= "</script>"
    ClientScript.RegisterClientScriptBlock(Me.GetType(), _
       "BlurScript", scriptText, False)
End Sub
End Class

这是FrontEnd.aspx文件

<%@ Page Language="vb" AutoEventWireup="false" CodeBehind="Test.aspx.vb" Inherits="WebApplication1.Test" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" >
<head>
<title>Test Page</title>
</head>
<body>
<h3>Test Page</h3>
<form id="form1" runat="server">
<asp:TextBox id="TextBox1" columns="54" 
 Text="Click here then outside" 
 runat="server" onBlur="DisplayBlurMessage();"/>  
</form>
</body>
</html>

当我点击文本框查看页面时,javascript调试器会给我一个错误,因为源代码中没有定义javascript。

然而,我可以通过在aspx文件中的标签中放入Page_Load子,然后直接访问文本框的属性来实现它。但这不是我想要的。

基本上,对于我的最后一页,我想迭代页面上的所有文本框,然后给它们一个使用id的onBlur和onFocus方法。

这可能吗?我看不出哪里出了问题。

请帮助:(

您可能在以下行中出现javascript错误:

ClientScript.RegisterClientScriptBlock(Me.GetType(), _
       "BlurScript", scriptText, True)

True意味着scriptText应该用脚本标记包装,但您已经包含了脚本标记。将此布尔值更改为False或删除脚本标记(请参阅文档):

选项a:

Dim scriptText As String = ""
scriptText &= "function DisplayBlurMessage(){alert('you clicked outside the textbox');}"
ClientScript.RegisterClientScriptBlock(Me.GetType(), _
   "BlurScript", scriptText, True)

选项b:

Dim scriptText As String = ""
scriptText &= "<script language='javascript'>"
scriptText &= "function DisplayBlurMessage(){alert('you clicked outside the textbox');}"
scriptText &= "</script>"
ClientScript.RegisterClientScriptBlock(Me.GetType(), _
   "BlurScript", scriptText, False)

编辑:

为了注册脚本,您需要在页面中有一个ScriptManager。在表单中添加以下内容:

<asp:ScriptManager ID="ScriptManager1" runat="server" />

试试这个:

RegisterClientScriptBlock的最后一个参数应为false

  ClientScript.RegisterClientScriptBlock(Me.GetType(), _
       "BlurScript", scriptText, False)

http://msdn.microsoft.com/en-us/library/bahh2fef.aspx

编辑:在页眉中,还需要放置CodeBehind="Test.aspx.vb"Inherits="yourproject.Test"

<%@ Page Language="VB" AutoEventWireup="True" CodeBehind="Test.aspx.vb" Inherits="yourproject.Test" %>