簡體   English   中英

jQuery檢查數據庫中的電子郵件可用性/重復性

[英]jquery to check Email availability/duplication in database

我正在嘗試檢查文本框的文本更改事件中的電子郵件可用性。 下面是代碼(我從網上撿來的):

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;
 }

    }
 }

在返回值行中出現錯誤。 正確的語法是什么? 另外,應該顯示如下圖像: 吶

因此,我需要在.aspx頁上具有圖像控件嗎? 因為我從此代碼中獲得的文章,沒有提到具有圖像控件。 如果是的話,我該如何將它們與代碼綁定在一起?

更新:這是我從http://www.dotnetspark.com/kb/Content.aspx?id=1278獲得代碼的鏈接

這篇文章缺少什么? 還有什么需要做的? 有人請..我需要這個...

您使用的雙引號錯誤。

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

生成HTML或類似這樣的標記確實是個壞習慣。 考慮在客戶端將其更改為模板系統,或者在后端找到更優雅的解決方案。

您似乎正在嘗試調用C#代碼用來檢查客戶端Ajax調用中是否有電子郵件的存儲過程。 您應該改為調用已定義的方法。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM