什么是AJAx:Asynchronous Javascript and XML
中文意思:异步JavaScript 和XML
批一种创建交互式网页应用的网页开发技术。
AJAX优点
1.Ajax 在本质上是一个浏览器端的技术。
2.Ajax技术之主要目的在于局部交换客户端及服务器间的数据。
3.这个技术的主角XMLHttpRequest的最主要特点,在于能够不用重新载入版面来更新资料,也就是所谓的Refresh withou Reload(轻刷新)
4.与服务器之间的沟通,完全是透过Javascript来实现的。
5.使用XMLHttpRequest本身传送的数据量很小,所以反应会更快,也就让网络程式更像一个桌面应用程序。
6AJX就是运用Javascript 在后台悄悄帮你去跟服务器要资料,最后再由Javascript 或Dom来帮你呈现结果,因为所有动作都是由Javascript 代劳,所以少去了网页重载的麻烦,使用者也感受不一以等待的痛苦。

<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title></title>
    <script type="text/javascript">
        function createXhr() {
            var xhobj = false;
            try {
                xhobj = new ActiveXObject("Msxml2.XMLHTTP");//ie msxml 3.0
            } catch (e) {
                try {
                    xhobj = new ActiveXObject("Microsoft.XMLHTTP")//ie msxml 2.6
                }
                catch (e2) {
                    xhobj = false;
                }
            }
            if (!xhobj && typeof XMLHttpRequest != "undefined") //Firefox,Opera 8.0 Safari
            {
                xhobj = new XMLHttpRequest();
            }

return xhobj;
        }
        window.onload = function () {
            document.getElementById("btnLoginGet").onclick = doLoginGet;
            document.getElementById("btnLoginPost").onclick = doLoginPost;
        }
        function doLoginGet() {
            //获取异步对象;
            var xhr = createXhr();
            //设置好参数 请求方式,请求URL,是否启用异步
            xhr.open("get", "LoginAjax.ashx", true);
            //设置get方式不使用缓存
            xhr.setRequestHeader("if-Modlfied-Sine", 0);
            //设置异步对象的回调函数---每当异步对象的准备状态发生改变的时候调用
            xhr.onreadystatechange = function () {
                //当readyState=4的时候,就说明 异步对象已经 从服务器获得了返回的数据
                if (xhr.readyState == 4) {
                    var res = xhr.responseText;
                    alert(res);
                    //获得响应报文头所有信息
                    var headerInfo = xhr.getAllResponseHeaders();
                    alert(headerInfo);
                }

};
            xhr.send(null);
        }
        function doLoginPost() {
            //获取异步对象;
            var xhr = createXhr();
            //设置好参数 请求方式,请求URL,是否启用异步
            xhr.open("post", "LoginAjax.ashx", true);
            //指定数据提交格式
            xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
            //设置get方式不使用缓存
            xhr.setRequestHeader("if-Modlfied-Sine", 0);
           
            //设置异步对象的回调函数---每当异步对象的准备状态发生改变的时候调用
            xhr.onreadystatechange = function () {
                //当readyState=4的时候,就说明 异步对象已经 从服务器获得了返回的数据
                if (xhr.readyState == 4) {
                    //判断服务器返回的状态码是否为 200 否则就是服务器端发生了意外
                    if (xhr.status == 200) {
                        var res = xhr.responseText;
                        alert(res);
                        //获得响应报文头所有信息
                        var headerInfo = xhr.getAllResponseHeaders();
                        alert(headerInfo);
                    }
                    else {
                        alert("对不起服务器繁忙~~~~~");
                    }

}

};
            xhr.send("txtName=孙业宝&&Pwd=123");
        }
    </script>
</head>
<body>
    <form action="" method="post">
        <input type="text" name="txtName" id="txtName" /><br />
        <input type="text" name="txtPwd" /><br />
        <!--<input type="text" name="txtCode" />
        <img title="点击换验证码" onclick="this.src ='LoginVode.ashx?i=' +new date();" align="middle" src="LoginVode.ashx" /><br />-->
        <input type="button" id="btnLoginGet" value="登录 By Get" />
        <input type="button" id="btnLoginPost" value="登录 By Post" />
    </form>
</body>
</html>

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;

namespace AJAX
{
    /// <summary>
    /// LoginAjax 的摘要说明
    /// </summary>
    public class LoginAjax : IHttpHandler
    {

public void ProcessRequest(HttpContext context)
        {
            context.Response.ContentType = "text/plain";
            context.Response.Write("Hello World");
        }

public bool IsReusable
        {
            get
            {
                return false;
            }
        }
    }
}

增加 js验证主要是为了用户的更好体验,如果用户禁用了Js照样 可以传到服务器,白浪费时间,减少服务器的压力。

复习下 AJAX的更多相关文章

  1. MVC 下 ajax调用 日期差值计算

    背景: 服务项目已有服务期起止时间From-To 现在要根据用户输入的新的起始时间, 和该服务期的原有区间值, 计算出新的服务期截止时间 即 NewServiceToDateTime = NewSer ...

  2. ie8或9下ajax跨域问题

    ie8或9下ajax跨域支持,添加如下代码 <!--[if (IE 8)|(IE 9)]><script src="https://cdn.bootcss.com/jque ...

  3. 重写了下Ajax请求Webservice,顺便复习一下Javascript的闭包概念

    var AjaxRequest = function(){ //返回处理结果的回调函数 this.agentCallBack = {}; //javascript 调用domino代理的方法. thi ...

  4. SpringMVC下Ajax请求的方法,@Responsebody如果返回的是布尔值,ajax不会接到任何回传数据

    SpringMVC框架下,如果用ajax向后台请求得方法如果使用@Responsebody返回布尔值的话,ajax得不到任何的回传数据. 但是如果返回String类型,就是正常的. 测试了下代码写得没 ...

  5. IE浏览器下ajax缓存导致数据不更新的解决方法

    摘自:http://www.iefans.net/ie-ajax-json-shuju-huancun/ 最近做设计的时候遇到一个小问题,当你用jquery的getjson函数从后台获取数据的时候,I ...

  6. 七牛---以一个七牛上传的实例小结下AJAX跨域【转】

    http://blog.csdn.net/netdxy/article/details/50699842 使用七牛过程中,很多用户或多或少遇到跨域的问题,这篇文章主要介绍下跨域的概念来看什么情况下会出 ...

  7. 关于IE下AJAX的问题探讨

    今天JS练手的时候,想封装一个发送AJAX请求的对象,当然,是想要兼容全浏览器的.代码如下: var Ajax = { xhr: null, callback: null, XMLHttp: func ...

  8. ***Jquery下Ajax与PHP数据交换

    一.前台传递字符串变量,后台返回字符串变量(非json格式) Javascript代码: 这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对 ...

  9. IE9下Ajax缓存问题

    使用jQuery的getJSON从后台定时获取数据并刷新界面,使用以下方法时,在Chrome,Firefox下没问题,但在IE9下却无法刷新数据 $.getJSON(webApp + "/G ...

随机推荐

  1. PHPWord生成word实现table合并(colspan和rowspan)

    PHPWord(http://phpword.codeplex.com/)是一个很好处理和生成WORD文档的工具,但是生成复杂的word,如colspan和rowspan的实现,还是需要你做些修改. ...

  2. 只有一个Service或Broadcast Reciver的android应用

    Service是android四大组件中与Activity最相似的组件,都可以代表可执行的程序. Service与Activity的区别在于:   (1).Service一直在后台运行,没有用户界面. ...

  3. 黄聪:C# 开发Chrome内核浏览器(WebKit.net)

    WebKit.net是对WebKit的.Net封装,使用它.net程序可以非常方便的集成和使用webkit作为加载网页的容器.这里介绍一下怎么用它来显示一个网页这样的一个最简单的功能. 第一步: 下载 ...

  4. 黄聪:jquery.confirm弹出确认消息

    1.插件介绍 该确认框的默认样式如: 1.1.插件默认参数 // 默认参数 $.confirm.defaults = { // 样式 css: "http://static.qianduan ...

  5. 解决pdm打开只显示表名不显示字段的步骤

    解决pdm打开只显示表名不显示字段的方法 选中PDM 依次点击 工具-->显示参数选择-->content 下面的table ,右边勾选上columns 点击OK 选择 all symbo ...

  6. DBA_Oracle Event等待事件分析(概念)

    2014-12-18 Created By BaoXinjian

  7. AP_AP系列 - 付款管理分析(案例)

    2014-07-08 Created By BaoXinjian 一.摘要 1. 付款 2. 发票付款概述 3. 使用发票工作台付款 4. 使用付款管理器付款 5. 银行账户模型 二.流程分析 1. ...

  8. python 爬虫抓取心得

    quanwei9958 转自 python 爬虫抓取心得分享 urllib.quote('要编码的字符串') 如果你要在url请求里面放入中文,对相应的中文进行编码的话,可以用: urllib.quo ...

  9. CentOS配置网卡,重启网络显示:Device does not seem to be present(转载)

    From:http://www.cnblogs.com/fbwfbi/archive/2013/04/29/3050907.html 一.故障现象: [root@c1node01 ~]# servic ...

  10. R如何检验类别变量(nominal variable)与其他变量之间的相关性

    1.使用Pearson积差相关系性进行检验的话可以判断两个变量之间的相关性是否显著以及相关性的强度 显著性检验 (significant test) 连续变量 vs 类别变量 (continuous ...