.net采用ajax实现邮箱注册和地区选择实例
本文实例讲述了.net采用ajax实现邮箱注册和地区选择的方法。分享给大家供大家参考。具体实现方法如下:
首先要知道ajax是 asynchronous javascript and xml(以及 dhtml 等)的缩写.
ajax就是在浏览器上同服务器实现异步交互。在xmlhttprequest被广泛使用之前,用户停留在页面上没有办法实现局部更新的功能,只能通过刷新整个页面来获取最新的数据,而由此代码的代价是需要传输大量的数据,而且有可能临时的一些用户信息也会丢失,而ajax的使用实现了局部更新页面内容的作用,原理是调用xmlhttprequest这个代理,向服务发送请求,之后通过ajax定义的处理接口来更新页面的内容。
接下来用ajax实现邮箱注册和地区选择实例来说明:
首先前台部分:
<!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的初步练习使用</title>
<style type="text/css">
div{width:800px;margin:0 auto;height:25px;}
</style>
<script type="text/javascript">
function createrequest()//创建对象
{
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()//发送请求
{
if(document.forms[0].useremail.value=="")
{
alert("用户邮箱不可为空!");
document.forms[0].useremail.focus();
return false;
}
req = createrequest();//创建ajax请求对象
req.open("get","default.aspx?email="+document.forms[0].useremail.value);
req.send("");//打开服务器连接,发送请求
req.onreadystatechange = dealmethod;//设置服务器响应完成后要运行的函数
}
function dealmethod()//调用函数
{
if(req.readystate==4&&req.status==200)//此时是服务器已经响应完成状态
{
if(req.responsetext=="0")//responsetext为服务器响应值属性
document.getelementbyid("canuse").innerhtml = "<img src='//files.jb51.net/file_images/article/201410/icon_need.gif' />"+"该邮箱已注册";
else
document.getelementbyid("canuse").innerhtml = "<img src='//files.jb51.net/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)//注册邮箱
{
//通常情况下,这里的数据来源应该是从某一个数据库里面读取的,这里为了方便就随便的定义了一个死板的数据代替了
string bbb = "2320774925@qq.com";
string aaa = request.querystring["email"];
if (aaa == bbb)
response.write("0");
else
response.write("1");
response.end();
}
//常规情况下,接下来的两个处理部分应该用到两张数据表
if (request.querystring["selected"] != null)//初始化下拉框
{
//通常情况下这里的数据应该是从数据库里面读取的,然后获取到省份编号为1对应下的所有城市编号和城市名称,接着按照某些方法首先将省份表里面的两列数据组合成形如"1,河南|2,浙江|3,湖北|4,江苏|5,安徽|6,山东|7,江西“这样的字符串,最后加上省份编号为1对应下的所有城市编号和城市名称最终形成形如"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)//改变省份触动城市的改变
{
//通常情况下这里的数据依然应该是从数据库里面读取的,在前端部分,初始化了下拉框之后,所有的省份将被填充到province下拉框中,省份编号为1 的所有城市也将被填充到city下拉框中,此时,当你重新选择省份的时候,服务器将会接收到一个新的数据,其实这个数据也就是所谓的省份编号了,然后这里 通过这个省份编号获得对应下的所有城市编号和城市名称,通过一定的方法处理最终获得形如"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,济南|2,青岛|3,淄博|4,枣庄|5,东营");
else
response.write("1,南昌|2,景德镇|3,萍乡|4,九江|5,新余");
response.end();
}
}
}
希望本文所述对大家的.net程序设计有所帮助。