[英]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.