濮阳杆衣贸易有限公司

主頁(yè) > 知識(shí)庫(kù) > .net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例

.net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例

熱門標(biāo)簽:昆明語(yǔ)音電銷機(jī)器人價(jià)格 百度地圖怎樣做地圖標(biāo)注 浦發(fā)電話機(jī)器人提醒還款 柳州電銷機(jī)器人公司 騰訊地圖標(biāo)注手機(jī) 電銷語(yǔ)音機(jī)器人型號(hào)參數(shù) 征途美甲店地圖標(biāo)注 400電話如何申請(qǐng)取消 太原400電話上門辦理

本文實(shí)例講述了.net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇的方法。分享給大家供大家參考。具體實(shí)現(xiàn)方法如下:

首先要知道Ajax是 Asynchronous JavaScript and XML(以及 DHTML 等)的縮寫(xiě).

ajax就是在瀏覽器上同服務(wù)器實(shí)現(xiàn)異步交互。在XMLhttpRequest被廣泛使用之前,用戶停留在頁(yè)面上沒(méi)有辦法實(shí)現(xiàn)局部更新的功能,只能通過(guò)刷新整個(gè)頁(yè)面來(lái)獲取最新的數(shù)據(jù),而由此代碼的代價(jià)是需要傳輸大量的數(shù)據(jù),而且有可能臨時(shí)的一些用戶信息也會(huì)丟失,而ajax的使用實(shí)現(xiàn)了局部更新頁(yè)面內(nèi)容的作用,原理是調(diào)用XMLhttpRequest這個(gè)代理,向服務(wù)發(fā)送請(qǐng)求,之后通過(guò)ajax定義的處理接口來(lái)更新頁(yè)面的內(nèi)容。

接下來(lái)用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例來(lái)說(shuō)明:

首先前臺(tái)部分:

復(fù)制代碼 代碼如下:
%@ Page Language="C#" AutoEventWireup="true" CodeBehind="Default.aspx.cs" Inherits="WebApplication2._Default" %>
!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)建對(duì)象
{
           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;//注冊(cè)郵箱
function sendRequest()//發(fā)送請(qǐng)求
{
            if(document.forms[0].useremail.value=="")
            {
                alert("用戶郵箱不可為空!");
                document.forms[0].useremail.focus();
                return false;
            }
            req = createRequest();//創(chuàng)建Ajax請(qǐng)求對(duì)象
            req.open("GET","default.aspx?Email="+document.forms[0].useremail.value);
            req.send("");//打開(kāi)服務(wù)器連接,發(fā)送請(qǐng)求
            req.onreadystatechange = dealMethod;//設(shè)置服務(wù)器響應(yīng)完成后要運(yùn)行的函數(shù)
}
function dealMethod()//調(diào)用函數(shù)
{
            if(req.readyState==4req.status==200)//此時(shí)是服務(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' />"+"該郵箱已注冊(cè)";
                else
                    document.getElementById("canuse").innerHTML = "img src='//img.jbzj.com/file_images/article/201410/icon_error.gif'/>"+"該郵箱未注冊(cè)";
            }
}
var req2=null;//初始化下拉框
function GetSelect()
{
            req2 = createRequest();
            req2.open("GET","default.aspx?Selected=1");
            req2.send("");
            req2.onreadystatechange=changeSelected;
}
function changeSelected()
{
            if(req2.readyState==4req2.status==200)
            {
                var s = req2.responseText;
                var provinces = s.split('')[0].split('|');//在后臺(tái)返回字段中獲得省份子列如(1,河南),(2,江西)等
                var cities = s.split('')[1].split('|');//在后臺(tái)返回字段中獲得城市子列如(1,鄭州),(2,洛陽(yáng)),(3,開(kāi)封)等
                document.forms[0].province.length=0;
                for(var i=0;iprovinces.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);//將省份編號(hào)和省份名分別以value和text的形式添加到select下的option里面
                }
                document.forms[0].city.length=0;
                for(var j=0;jcities.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);//將城市編號(hào)和城市名分別以value和text的形式添加到select下的option里面
                }
            }
}
var req3=null;//改變省份觸動(dòng)城市的改變
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==4req3.status==200)
            {
                var s = req3.responseText;
                var cities = s.split('|');
                document.forms[0].city.length=0;
                for(var i=0;icities.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="注冊(cè)" onclick="sendRequest();"/>/th>
    /tr>
    /table>
    /form>
/body>
script type="text/javascript">
GetSelect();
/script>
/html>

然后是后臺(tái)部分:

復(fù)制代碼 代碼如下:
public partial class _Default : System.Web.UI.Page
{
        protected void Page_Load(object sender, EventArgs e)
        {
            if (Request.QueryString["Email"] != null)//注冊(cè)郵箱
            {

               //通常情況下,這里的數(shù)據(jù)來(lái)源應(yīng)該是從某一個(gè)數(shù)據(jù)庫(kù)里面讀取的,這里為了方便就隨便的定義了一個(gè)死板的數(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ī)情況下,接下來(lái)的兩個(gè)處理部分應(yīng)該用到兩張數(shù)據(jù)表
            if (Request.QueryString["Selected"] != null)//初始化下拉框
            {

               //通常情況下這里的數(shù)據(jù)應(yīng)該是從數(shù)據(jù)庫(kù)里面讀取的,然后獲取到省份編號(hào)為1對(duì)應(yīng)下的所有城市編號(hào)和城市名稱,接著按照某些方法首先將省份表里面的兩列數(shù)據(jù)組合成形如"1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西“這樣的字符串,最后加上省份編號(hào)為1對(duì)應(yīng)下的所有城市編號(hào)和城市名稱最終形成形如"1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西1,鄭州|2,洛陽(yáng)|3,開(kāi)封|4,信陽(yáng)|5,南陽(yáng)|6,駐馬店|7,安陽(yáng)|8,鶴壁|9,濮陽(yáng)|10,平頂山"這樣的一列字符串回傳到前端
                string result = "1,河南|2,浙江|3,湖北|4,江蘇|5,安徽|6,山東|7,江西1,鄭州|2,洛陽(yáng)|3,開(kāi)封|4,信陽(yáng)|5,南陽(yáng)|6,駐馬店|7,安陽(yáng)|8,鶴壁|9,濮陽(yáng)|10,平頂山";
                Response.Write(result);
                Response.End();
            }
            if (Request.QueryString["ProId"] != null)//改變省份觸動(dòng)城市的改變
            {

               //通常情況下這里的數(shù)據(jù)依然應(yīng)該是從數(shù)據(jù)庫(kù)里面讀取的,在前端部分,初始化了下拉框之后,所有的省份將被填充到province下拉框中,省份編號(hào)為1 的所有城市也將被填充到city下拉框中,此時(shí),當(dāng)你重新選擇省份的時(shí)候,服務(wù)器將會(huì)接收到一個(gè)新的數(shù)據(jù),其實(shí)這個(gè)數(shù)據(jù)也就是所謂的省份編號(hào)了,然后這里 通過(guò)這個(gè)省份編號(hào)獲得對(duì)應(yīng)下的所有城市編號(hào)和城市名稱,通過(guò)一定的方法處理最終獲得形如"1,鄭州|2,洛陽(yáng)|3,開(kāi)封|4,信陽(yáng)|5,南陽(yáng)"這樣的字符串回傳給前端
                int num = Int32.Parse(Request.QueryString["ProId"]);
                if (num == 1)
                    Response.Write("1,鄭州|2,洛陽(yáng)|3,開(kāi)封|4,信陽(yáng)|5,南陽(yáng)");
                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,無(wú)錫|3,徐州|4,常州|5,蘇州");
                if (num == 5)
                    Response.Write("1,合肥|2,蕪湖|3,蚌埠|4,淮南|5,馬鞍山");
                if (num == 6)
                    Response.Write("1,濟(jì)南|2,青島|3,淄博|4,棗莊|5,東營(yíng)");
                else
                    Response.Write("1,南昌|2,景德鎮(zhèn)|3,萍鄉(xiāng)|4,九江|5,新余");
                Response.End();
            }
        }
}

希望本文所述對(duì)大家的.net程序設(shè)計(jì)有所幫助。

您可能感興趣的文章:
  • 身份證號(hào)碼前六位所代表的省,市,區(qū), 以及地區(qū)編碼下載
  • 封裝好的省市地區(qū)聯(lián)動(dòng)控件附下載
  • 仿51JOB的地區(qū)選擇效果(可選擇多個(gè)地區(qū))
  • jquery的ajax從純真網(wǎng)(cz88.net)獲取IP地址對(duì)應(yīng)地區(qū)名
  • Nginx geoip模塊實(shí)現(xiàn)地區(qū)性負(fù)載均衡
  • 基于json的jquery地區(qū)聯(lián)動(dòng)效果代碼
  • 中國(guó)地區(qū)三級(jí)聯(lián)動(dòng)下拉菜單效果分析
  • 根據(jù)IP的地址,區(qū)分不同的地區(qū),查看不同的網(wǎng)站頁(yè)面的js代碼
  • PHP根據(jù)IP判斷地區(qū)名信息的示例代碼
  • 輕松實(shí)現(xiàn)Android仿淘寶地區(qū)選擇功能

標(biāo)簽:江蘇 陽(yáng)泉 白山 天門 德陽(yáng) 新疆 蘭州 張家界

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《.net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例》,本文關(guān)鍵詞  .net,采用,ajax,實(shí)現(xiàn),郵箱,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《.net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于.net采用ajax實(shí)現(xiàn)郵箱注冊(cè)和地區(qū)選擇實(shí)例的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    商丘市| 临沭县| 乌兰浩特市| 柞水县| 宝应县| 普兰店市| 绥芬河市| 炎陵县| 垫江县| 洛南县| 三门峡市| 朝阳区| 贵阳市| 利辛县| 剑川县| 高淳县| 班玛县| 汨罗市| 甘谷县| 诸暨市| 三台县| 左权县| 集安市| 古交市| 石楼县| 交口县| 方山县| 武功县| 怀化市| 高青县| 长阳| 上栗县| 宜兰县| 繁昌县| 元氏县| 剑阁县| 乐亭县| 宝清县| 镇平县| 凤凰县| 安多县|