jquery检查数据库中的电子邮件可用性/重复

时间:2013-03-22 07:14:31

标签: jquery asp.net

我正在尝试检查文本框的文本更改事件的电子邮件可用性。下面是代码(我从网上拿起):

HTML(javascript):

    <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.0/jquery.min.js"></script>

<script type="text/javascript">

    $(document).ready(function () {

        $("#<%=txtEmailAddress.UniqueID%>").change(function () {

            var uname = $("#<%=txtEmailAddress.UniqueID%>");

            var msgbox = $("#status");

            if (Email.val().length > 0) {

                $.ajax({

                    type: "POST",

                    url: "SignUp.aspx/usp_CheckEmail",

                    data: "{'args': '" + Email.val() + "'}",

                    contentType: "application/json; charset=utf-8",

                    dataType: "json",

                    success: function (msg) {

                        if (msg.d == 'Available') {

                            Email.removeClass("notavailablecss");

                            Email.addClass("availablecss");

                            msgbox.html('<img src="Images/a.png"> <font color="Green"> Available </font>');

                        }
                        else {
                            Email.removeClass("availablecss");

                            Email.addClass("notavailablecss");

                            msgbox.html(msg.d);

                        }
                    }
                });
            }
            else {

                Email.addClass("notavailablecss");

                msgbox.html('<font color="#cc0000">Email must be unique</font>');

            }

        });

    });

CS:

 [System.Web.Services.WebMethod]

protected void txtPassword_TextChanged(object sender, EventArgs e, string args)
    {
 string returnValue = string.Empty;

 SqlConnection con = new SqlConnection(System.Configuration.ConfigurationManager.AppSettings["ConnectionString"]);


try
{

SqlCommand sqlCmd = new SqlCommand("usp_CheckEmail", con);

sqlCmd.CommandType = CommandType.StoredProcedure;

sqlCmd.Parameters.AddWithValue("@Email", args.Trim());

con.Open();

int success = int.Parse((sqlCmd.ExecuteScalar().ToString()));

if(success == 1) // Email Not Available
{
returnValue = "<img src="Images1/n.png"><font color="#cc0000"><b>'" + args + "'</b> is    already in use.</font>";   **//getting syntax error here**

  }
  else if(success == 0)//Email is available
{
 returnValue = "Available";
 }

}
 catch
 {
 //Handle Error
 }
 finally
 {
 con.Close();
 }

return returnValue;
 }

    }
 }

在返回值行中出错。什么是正确的语法?此外,它应该显示如下图像:na

那么,我需要在.aspx页面上设置图像控件吗?因为我从这个代码得到的文章,没有提到有图像控件。如果是的话,我如何将它们与代码绑定呢?

更新:以下是我从中获取代码的链接 http://www.dotnetspark.com/kb/Content.aspx?id=1278

文章中遗漏了什么?还有什么需要做的?有人请..我需要这个...

2 个答案:

答案 0 :(得分:0)

您错误地使用双引号。

returnValue = "<img src=\"Images1/n.png\"><font color=\"#cc0000\"><b>'" + args + "'</b> is    already in use.</font>";

生成HTML或任何这样的标记是非常糟糕的习惯。考虑将其更改为客户端的模板系统,或者在后端找到更优雅的解决方案。

答案 1 :(得分:0)

您似乎正在尝试调用C#代码用来检查客户端Ajax调用中是否有电子邮件的存储过程。你应该调用你定义的方法。