复习下 AJAX
什么是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的更多相关文章
- MVC 下 ajax调用 日期差值计算
背景: 服务项目已有服务期起止时间From-To 现在要根据用户输入的新的起始时间, 和该服务期的原有区间值, 计算出新的服务期截止时间 即 NewServiceToDateTime = NewSer ...
- ie8或9下ajax跨域问题
ie8或9下ajax跨域支持,添加如下代码 <!--[if (IE 8)|(IE 9)]><script src="https://cdn.bootcss.com/jque ...
- 重写了下Ajax请求Webservice,顺便复习一下Javascript的闭包概念
var AjaxRequest = function(){ //返回处理结果的回调函数 this.agentCallBack = {}; //javascript 调用domino代理的方法. thi ...
- SpringMVC下Ajax请求的方法,@Responsebody如果返回的是布尔值,ajax不会接到任何回传数据
SpringMVC框架下,如果用ajax向后台请求得方法如果使用@Responsebody返回布尔值的话,ajax得不到任何的回传数据. 但是如果返回String类型,就是正常的. 测试了下代码写得没 ...
- IE浏览器下ajax缓存导致数据不更新的解决方法
摘自:http://www.iefans.net/ie-ajax-json-shuju-huancun/ 最近做设计的时候遇到一个小问题,当你用jquery的getjson函数从后台获取数据的时候,I ...
- 七牛---以一个七牛上传的实例小结下AJAX跨域【转】
http://blog.csdn.net/netdxy/article/details/50699842 使用七牛过程中,很多用户或多或少遇到跨域的问题,这篇文章主要介绍下跨域的概念来看什么情况下会出 ...
- 关于IE下AJAX的问题探讨
今天JS练手的时候,想封装一个发送AJAX请求的对象,当然,是想要兼容全浏览器的.代码如下: var Ajax = { xhr: null, callback: null, XMLHttp: func ...
- ***Jquery下Ajax与PHP数据交换
一.前台传递字符串变量,后台返回字符串变量(非json格式) Javascript代码: 这里,为了解决Ajax数据传递出现的汉字乱码,在字符串传递之前,使用javascript函数escape()对 ...
- IE9下Ajax缓存问题
使用jQuery的getJSON从后台定时获取数据并刷新界面,使用以下方法时,在Chrome,Firefox下没问题,但在IE9下却无法刷新数据 $.getJSON(webApp + "/G ...
随机推荐
- Android的CursorLoader用法小结
工作内容集中到Contact模块,这个应用查询数据的地方很多,其使用了CursorLoader这个工具大大简化了代码复杂度.Android自3.0提供了Loader机制,当时google的API只是简 ...
- 在mac上安装svn客户端
mac 10.8上面,默认是没有svn客户端的,可以通过以下两种方式来安装: 1.单独安装xcode命令行工具,安装完成后,在终端中就可以使用svn命令了,目前版本是1.6.18: 2.去 ...
- IOS 日志输出控制
用以下内容可以控制在debug版本中打印日志,而在release版本中不打印 #ifdef DEBUG# define DBLog(format,...) NSLog((@"[%s][%s] ...
- 2016 Multi-University Training Contest 5 Divide the Sequence
Divide the Sequence 题意: 给你一个序列A,问你最多能够分成多少个连续子序列,使得每个子序列的所有前缀和均不小于0 题解: 这题是比赛时候的水题,但我比的时候也就做出这一题, = ...
- poj_2421_mst
D - Constructing Roads Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%I64d & %I ...
- "运行时"如何解析类型引用
先将下面的代码保存到文本中,存放到一个目录下面,E:\aa.txt public sealed class Program{ public static void Main(){ System.Con ...
- DDoS-Deflate安装及配置
(D)DoS-Deflate是一款免费的用来防御和减轻DDoS攻击.它通过netstat监测跟踪创建大量网络连接的IP地址,在检测到某个结点超过预设的限制时,该程序会通过APF或iptables禁止或 ...
- 转--简单工厂模式 Simple Factory
简单工厂模式的作用就是定义一个用于创建对象的接口 在简单工厂模式中,一个工厂类处于对产品类实例化调用的中心位置上,它决定那一个产品类应当被实例化. 先来看看它的组成: 1) 工厂类角色 ...
- Android应用框架浅析
http://blog.csdn.net/yanbober/article/category/3206943 Android应用层View绘制流程与源码分析 http://blog.csdn.ne ...
- oninput 属性
在HTML5中,新增加了oninput属性,它和onchange 的不同就是立刻发生,而onchange 是在失去焦点的时候才发生 <script> function rangeChang ...