.net采用ajax實(shí)現(xiàn)郵箱注冊和地區(qū)選擇實(shí)例
本文實(shí)例講述了.net采用ajax實(shí)現(xiàn)郵箱注冊和地區(qū)選擇的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:
首先要知道Ajax是 Asynchronous JavaScript and XML(以及 DHTML 等)的縮寫.
ajax就是在瀏覽器上同服務(wù)器實(shí)現(xiàn)異步交互。在XMLhttpRequest被廣泛使用之前,用戶停留在頁面上沒有辦法實(shí)現(xiàn)局部更新的功能,只能通過刷新整個頁面來獲取最新的數(shù)據(jù),而由此代碼的代價是需要傳輸大量的數(shù)據(jù),而且有可能臨時的一些用戶信息也會丟失,而ajax的使用實(shí)現(xiàn)了局部更新頁面內(nèi)容的作用,原理是調(diào)用XMLhttpRequest這個代理,向服務(wù)發(fā)送請求,之后通過ajax定義的處理接口來更新頁面的內(nèi)容。
接下來用ajax實(shí)現(xiàn)郵箱注冊和地區(qū)選擇實(shí)例來說明:
首先前臺部分:
<!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 runat="server">
<title>ajax的初步練習(xí)使用</title>
<style type="text/css">
div{width:800px;margin:0 auto;height:25px;}
</style>
<script type="text/javascript">
function createRequest()//創(chuàng)建對象
{
var request;
try
{
request = new XMLHttpRequest();
}
catch(microspft)
{
try
{
request = new ActiveXObject("Msxml2.XMLHTTP");
}
catch(othermicrosoft)
{
try
{
request = new ActiveXObject("Microsoft.XMLHTTP");
}
catch(failed)
{
request = null;
}
}
}
return request;
}
var req = null;//注冊郵箱
function sendRequest()//發(fā)送請求
{
if(document.forms[0].useremail.value=="")
{
alert("用戶郵箱不可為空!");
document.forms[0].useremail.focus();
return false;
}
req = createRequest();//創(chuàng)建Ajax請求對象
req.open("GET","default.aspx?Email="+document.forms[0].useremail.value);
req.send("");//打開服務(wù)器連接,發(fā)送請求
req.onreadystatechange = dealMethod;//設(shè)置服務(wù)器響應(yīng)完成后要運(yùn)行的函數(shù)
}
function dealMethod()//調(diào)用函數(shù)
{
if(req.readyState==4&&req.status==200)//此時是服務(wù)器已經(jīng)響應(yīng)完成狀態(tài)
{
if(req.responseText=="0")//responseText為服務(wù)器響應(yīng)值屬性
document.getElementById("canuse").innerHTML = "<img src='//img.jbzj.com/file_images/article/201410/icon_need.gif' />"+"該郵箱已注冊";
else
document.getElementById("canuse").innerHTML = "<img src='//img.jbzj.com/file_images/article/201410/icon_error.gif'/>"+"該郵箱未注冊";
}
}
var req2=null;//初始化下拉框
function GetSelect()
{
req2 = createRequest();
req2.open("GET","default.aspx?Selected=1");
req2.send("");
req2.onreadystatechange=changeSelected;
}
function changeSelected()
{
if(req2.readyState==4&&req2.status==200)
{
var s = req2.responseText;
var provinces = s.split('&')[0].split('|');//在后臺返回字段中獲得省份子列如(1,河南),(2,江西)等
var cities = s.split('&')[1].split('|');//在后臺返回字段中獲得城市子列如(1,鄭州),(2,洛陽),(3,開封)等
document.forms[0].province.length=0;
for(var i=0;i<provinces.length;i++)
{
var op = new Option();
op.value = provinces[i].split(',')[0];
op.text = provinces[i].split(',')[1];
document.forms[0].province.options.add(op);//將省份編號和省份名分別以value和text的形式添加到select下的option里面
}
document.forms[0].city.length=0;
for(var j=0;j<cities.length;j++)
{
var op2 = new Option();
op2.value = cities[j].split(',')[0];
op2.text = cities[j].split(',')[1];
document.forms[0].city.options.add(op2);//將城市編號和城市名分別以value和text的形式添加到select下的option里面
}
}
}
var req3=null;//改變省份觸動城市的改變
function GetCity()
{
req3 = createRequest();
req3.open("GET","default.aspx?ProId="+document.forms[0].province.value);
req3.send("");
req3.onreadystatechange=changeCity;
}
function changeCity()
{
if(req3.readyState==4&&req3.status==200)
{
var s = req3.responseText;
var cities = s.split('|');
document.forms[0].city.length=0;
for(var i=0;i<cities.length;i++)
{
var op = new Option();
op.value = cities[i].split(',')[0];
op.text = cities[i].split(',')[1];
document.forms[0].city.options.add(op);
}
}
}
</script>
</head>
<body>
<form id="form1" runat="server">
<table align="center">
<tr>
<th>Email</th>
<th><input type="text" name="useremail" value=""/></th>
<th id="canuse"></th>
<th></th>
</tr>
<tr>
<th><select name="province" onchange="GetCity();"></select></th>
<th><select name="city"></select></th>
<th><input type="button" value="注冊" onclick="sendRequest();"/></th>
</tr>
</table>
</form>
</body>
<script type="text/javascript">
GetSelect();
</script>
</html>
然后是后臺部分:
{
protected void Page_Load(object sender, EventArgs e)
{
if (Request.QueryString["Email"] != null)//注冊郵箱
{
//通常情況下,這里的數(shù)據(jù)來源應(yīng)該是從某一個數(shù)據(jù)庫里面讀取的,這里為了方便就隨便的定義了一個死板的數(shù)據(jù)代替了
string bbb = "2320774925@qq.com";
string aaa = Request.QueryString["Email"];
if (aaa == bbb)
Response.Write("0");
else
Response.Write("1");
Response.End();
}
//常規(guī)情況下,接下來的兩個處理部分應(yīng)該用到兩張數(shù)據(jù)表
if (Request.QueryString["Selected"] != null)//初始化下拉框
{
//通常情況下這里的數(shù)據(jù)應(yīng)該是從數(shù)據(jù)庫里面讀取的,然后獲取到省份編號為1對應(yīng)下的所有城市編號和城市名稱,接著按照某些方法首先將省份表里面的兩列數(shù)據(jù)組合成形如"1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西“這樣的字符串,最后加上省份編號為1對應(yīng)下的所有城市編號和城市名稱最終形成形如"1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西&1,鄭州|2,洛陽|3,開封|4,信陽|5,南陽|6,駐馬店|7,安陽|8,鶴壁|9,濮陽|10,平頂山"這樣的一列字符串回傳到前端
string result = "1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西&1,鄭州|2,洛陽|3,開封|4,信陽|5,南陽|6,駐馬店|7,安陽|8,鶴壁|9,濮陽|10,平頂山";
Response.Write(result);
Response.End();
}
if (Request.QueryString["ProId"] != null)//改變省份觸動城市的改變
{
//通常情況下這里的數(shù)據(jù)依然應(yīng)該是從數(shù)據(jù)庫里面讀取的,在前端部分,初始化了下拉框之后,所有的省份將被填充到province下拉框中,省份編號為1 的所有城市也將被填充到city下拉框中,此時,當(dāng)你重新選擇省份的時候,服務(wù)器將會接收到一個新的數(shù)據(jù),其實(shí)這個數(shù)據(jù)也就是所謂的省份編號了,然后這里 通過這個省份編號獲得對應(yīng)下的所有城市編號和城市名稱,通過一定的方法處理最終獲得形如"1,鄭州|2,洛陽|3,開封|4,信陽|5,南陽"這樣的字符串回傳給前端
int num = Int32.Parse(Request.QueryString["ProId"]);
if (num == 1)
Response.Write("1,鄭州|2,洛陽|3,開封|4,信陽|5,南陽");
if (num == 2)
Response.Write("1,杭州|2,寧波|3,溫州|4,嘉興|5,湖州");
if (num == 3)
Response.Write("1,武漢|2,黃石|3,十堰|4,宜昌|5,荊州");
if (num == 4)
Response.Write("1,南京|2,無錫|3,徐州|4,常州|5,蘇州");
if (num == 5)
Response.Write("1,合肥|2,蕪湖|3,蚌埠|4,淮南|5,馬鞍山");
if (num == 6)
Response.Write("1,濟(jì)南|2,青島|3,淄博|4,棗莊|5,東營");
else
Response.Write("1,南昌|2,景德鎮(zhèn)|3,萍鄉(xiāng)|4,九江|5,新余");
Response.End();
}
}
}
希望本文所述對大家的.net程序設(shè)計有所幫助。
- 身份證號碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載
- 封裝好的省市地區(qū)聯(lián)動控件附下載
- 仿51JOB的地區(qū)選擇效果(可選擇多個地區(qū))
- jquery的ajax從純真網(wǎng)(cz88.net)獲取IP地址對應(yīng)地區(qū)名
- Nginx geoip模塊實(shí)現(xiàn)地區(qū)性負(fù)載均衡
- 基于json的jquery地區(qū)聯(lián)動效果代碼
- 中國地區(qū)三級聯(lián)動下拉菜單效果分析
- 根據(jù)IP的地址,區(qū)分不同的地區(qū),查看不同的網(wǎng)站頁面的js代碼
- PHP根據(jù)IP判斷地區(qū)名信息的示例代碼
- 輕松實(shí)現(xiàn)Android仿淘寶地區(qū)選擇功能
相關(guān)文章
Asp.NetCore3.1開源項目升級為.Net6.0的方法實(shí)現(xiàn)
自從.Net6.0出來后,一直想之前開發(fā)的項目升級.Net6.0,本文就詳細(xì)的介紹一下如何將Asp.NetCore3.1開源項目升級為.Net6.0,感興趣的小伙伴們可以參考一下2021-12-12ASP.NET?MVC使用Session會話保持表單狀態(tài)
這篇文章介紹了ASP.NET?MVC使用Session會話保持表單狀態(tài)的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-09-09通用?HTTP?簽名組件的另類實(shí)現(xiàn)方式
這篇文章主要介紹了通用?HTTP?簽名組件的另類實(shí)現(xiàn)方式,實(shí)現(xiàn)思路大概是采用鏈?zhǔn)秸{(diào)用的方式,使得簽名的步驟可以動態(tài)拼湊組合,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09ASP.NET?Core通過Microsoft.AspNetCore.App元包簡化程序集引用
這篇文章介紹了ASP.NET?Core通過Microsoft.AspNetCore.App元包簡化程序集引用的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07asp.net文件上傳功能(單文件,多文件,自定義生成縮略圖,水印)
上傳功能,是大家經(jīng)常用到了,可能每一個項目都可以會用到。網(wǎng)上到處都有上傳功能的代碼。比我寫的好的有很多。我這里也僅是分享我的代碼。2011-09-09ASP.NET Core中使用默認(rèn)MVC路由的配置
這篇文章主要介紹了ASP.NET Core中使用默認(rèn)MVC路由的配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02