AJAX 简单上手
没有AJAX会怎么样?普通的ASP.Net每次执行服务端方法的时候都要刷新当前页面,如实现显示服务器的时间
每次都要刷新页面的坏处:页面刷新打断用户操作、速度慢、增加服务器的流量压力。如果没有AJAX,
在youku看视频的过程中如果点击了“顶、踩”、评论、评论翻页,页面就会刷新,视频就会被打断
AJAX(Asynchronous JavaScript and XML,异步JavaScript和XML)是一种进行页面局部异步刷新
的技术。用AJAX 向服务器发送请求和获得服务器返回的数据并且更新到界面中,不是整个页面刷新,
而是在HTML页面中使用JavaScript创建XMLHTTPRequest对象来向服务器发出请求以及获得返回的数
据,就像JavaScript版的WebClient一样,在页面中由XMLHTTPRequest来发出Http请求和获得服务器的
返回数据,这样页面就不会刷新了。XMLHTTPRequest是AJAX的核心对象
AJAX的编写流程:
1.创建一个ActiveXObject类
2.open打开对象,并指定提交类型,请求页面
3.判断状态,进行相应的处理
4.对象send请求
开发一个AJAX功能需要开发服务端和客户端两块程序。以一个显示服务端时间为例
首先开发一个GetDate1.ashx,输出当前时间,在HTML页面中放一个按钮,在按钮的onclick中
创建XMLHTTP向GetDate1.ashx发送请求,获得返回的数据并且显示到界面上
面试常考:不使用UpdatePanel、JQuery等AJAX库编写一个AJAX程序
也可以在xmlhttp.open中向服务器传递参数:xmlhttp.open("POST","GetDate1.ashx?id=1", false),
如果传递给服务器的请求里有中文,则需要使用Javascript函数encodeURI来进行URL编码
案例1:将服务器的当前时间写入到 HTML中的Text中,要求不提交表单
<input id="Text1" type="text" />
<input id="Submit1" type="button" value="当前时间" onclick="btnGetdate()" />
2.写入AJAX的框架,在后台请求数据
<script type="text/javascript">
function btnGetdate() {
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); //创建XMLHTTP对象,相当于WebClient
if (!xmlhttp) {
alert("创建xmlhttp对象异常!");
return false;
}
xmlhttp.open("Get", "GetDate.ashx", false); //如果是GET请求,可能会出现缓存,flase 为同步,true 为异步 //准备向服务器的GetDate.ashx发出Get请求
//XMLHTTP默认(推荐)不是同步请求的,也就是open方法并不像WebClinent的DownloadString
//那样把服务器返回的数据拿到才返回,是异步的,因此需要监听onreadystatechange事件(准备状态事件) xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4) { //服务器返回了
if (xmlhttp.status == 200) { //如果状态码为200则是成功
document.getElementById("Text1").value = xmlhttp.responseText;
//responseText属性为服务器返回的文本
}
else {alert("AJAX无法请求!");}
}
}
xmlhttp.send(); //这时才开始发送请求
}
</script>
缓存的处理
只有GET请求才会有缓存,是由于它会判断请求的内容是否一样,如果一样则返回缓存
如果是POST请求就不会有缓存,处理原理:给它提交的内容里面,每次都不一样,如加入当前时间
如下 :
xmlhttp.open("Get", "GetDate.ashx?date="+new Date(), false); //date普通参数 new 当前时间
中文的处理
如果在请求中含有中文的话,可能会出现乱码,解决办法:利用encodeURI()进行转换
如下是没有做处理的:
xmlhttp.open("Get", "GetDate.ashx?&text=中国", false);
如下是处理过的:
xmlhttp.open("post", "GetDate.ashx?id="+encodeURI('中国'), false);
案例2:
用AJAX实现汇率转换,页面放一个文本框 (输入人民币)、一个下拉列表 (美元,日元, 币)、一个按钮,点击按钮在一个span中
显示转换后的金额。汇率计算在服务器端完成,假设汇率 (人民币/外币 ):7、0.1、0.9
1.HTMl页面设计,一个文本,一个下拉列表,一个按钮,一个文本
<input id="count" type="text" />
<select id="SelectType" name="D1">
<option value="1">美元</option>
<option value="2">日元</option>
<option value="3">港币</option>
</select>
<input id="Button1" type="button" value="转换" onclick="zhuanghuan()"/> //指定单击事件
<input id="requst" type="text" />
2.Javascript的编写(单击事件)AJAX的框架
function zhuanghuan() {
var amount = document.getElementById("count").value;
var type = document.getElementById("SelectType").value;
var xmlhttp = new ActiveXObject("Microsoft.XMLHTTP"); if (!xmlhttp) {
alert("创建xmlhttp对象异常!");
}
xmlhttp.open("Post", "huilv.ashx?amount=" + amount + "&type=" + type);
xmlhttp.onreadystatechange = function() {
if (xmlhttp.readyState == 4) {
if (xmlhttp.status == 200) {
document.getElementById("requst").value = xmlhttp.responseText;
}
}
}
xmlhttp.send();
}
3.后台处理程序的编写 huilv.ashx
public void ProcessRequest(HttpContext context)
{
context.Response.ContentType = "text/plain";
int amount =Convert.ToInt32(context.Request["amount"]);
int type =Convert.ToInt32(context.Request["type"]);
if (type == ) //美元
{
context.Response.Write(amount / );
}
else if(type == )//日元
{
context.Response.Write(amount * );
}
else if (type == )//港币
{
context.Response.Write(amount * / );
}
}
AJAX 简单上手的更多相关文章
- ajax简单后台交互
ajax简单后台交互 1,扯淡 单身的生活,大部分时间享受自由,小部分时间忍受寂寞. 生活有时候,其实蛮苦涩,让人难以下咽.那些用岁月积累起来的苦闷,无处宣泄,在自己的脑海里蔓延成一片片荆棘,让你每每 ...
- Spring Boot项目简单上手+swagger配置+项目发布(可能是史上最详细的)
Spring Boot项目简单上手+swagger配置 1.项目实践 项目结构图 项目整体分为四部分:1.source code 2.sql-mapper 3.application.properti ...
- ajax简单手写了一个猜拳游戏
使用ajax简单写一个猜拳游戏 HTML代码 <!DOCTYPE HTML> <html lang="en-US"> <head> <me ...
- javascript AJAX简单原理及什么是ajax
AJAX简单原理供初学者理解 AJAX的原理: Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面.这其 ...
- Tinker 热修复框架 简单上手教程
当你们看到Tinker的时候是不是有点愣逼这个是什么东西? 简单来说就是不需要重新下载app和重新安装app 来进行更新app的技术框架. 看看这个吧,我也是才学习 ,先做个学习记录 参考:Tinke ...
- Jquery Ajax简单封装(集中错误、请求loading处理)
Jquery Ajax简单封装(集中错误.请求loading处理) 对Jquery Ajax做了简单封装,错误处理,请求loading等,运用到项目中集中处理会很方便. 技术层面没有什么好说的,请求是 ...
- 前端(十七)—— jQuery基础:jQuery的基本使用、JQ功能概括、JS对象与JQ对象转换、Ajax简单应用、轮播图
jQuery的基本使用.JQ功能概括.JS对象与JQ对象转换.Ajax简单应用.轮播图 一.认识jQuery 1.什么是jQuery jQuery是对原生JavaScript二次封装的工具函数集合 j ...
- ajax简单封装
var xmlhttp = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP'); ...
- ajax简单后台交互-我们到底能走多远系列(28)
我们到底能走多远系列(28) 1,扯淡 单身的生活,大部分时间享受自由,小部分时间忍受寂寞. 生活有时候,其实蛮苦涩,让人难以下咽.那些用岁月积累起来的苦闷,无处宣泄,在自己的脑海里蔓延成一片片荆棘, ...
随机推荐
- Xamarin开发Android时Visual Studio 2012没有智能提示解决办法
Most of the people who work with Xamarin’s Mono for Android in Visual Studio 2012 face a bug where I ...
- 关于.net的一些基础知识(一)
一.GC工作原理: GC如其名,就是垃圾收集,当然这里仅就内存而言.Garbage Collector(垃圾收集器,在不至于混淆的情况下也成为GC)以应用程序的root为基础,遍历应用程序在Heap上 ...
- C#常用的集合类型(ArrayList类、Stack类、Queue类、Hashtable类、SortedList类)
1.ArrayList类 ArrayList类主要用于对一个数组中的元素进行各种处理.在ArrayList中主要使用Add.Remove.RemoveAt.Insert四个方法对栈进行操作.Add方法 ...
- python版的短信轰炸机smsbomb----------下篇(get)
在上一篇介绍的是post方式发送数据,可是有点站点是get方式发送数据,比如:http://www.oupeng.com/download,事实上方法差点儿相同. import httplib,url ...
- Android ListView分页加载时图片显示问题
场景:Android ListView需要分页加载,每个item中会有图片,图片又是从网络下载的. 问题:在滑动加载下一页时,上一页的图片明明已经下载完成了,但是无法显示出来. Bug重现: 1,加载 ...
- poj 3253 Fence Repair(优先队列+哈夫曼树)
题目地址:POJ 3253 哈夫曼树的结构就是一个二叉树,每个父节点都是两个子节点的和. 这个题就是能够从子节点向根节点推. 每次选择两个最小的进行合并.将合并后的值继续加进优先队列中.直至还剩下一个 ...
- careercup-排序和查找 11.5
11.5 有个排序后的字符串数组,其中散布着一些空字符串,编写一个方法,找出给定字符串的位置. 解法: 如果没有那些空字符串,就可以直接使用二分查找法.比较待查找字符串str和数组的中间元素,然后继续 ...
- careercup-排序和查找 11.4
11.4 设想你有一个20GB的文件,每一行一个字符串.请说明将如何对这个文件进行排序. 解法: 当面试官给出20GB大小的限制时,实际上在暗示些什么.就此题而言,这表明他们不希望你将数据全部载入内存 ...
- How Network Load Balancing Technology Works--reference
http://technet.microsoft.com/en-us/library/cc756878(v=ws.10).aspx In this section Network Load Balan ...
- Android开发之”再按一次退出程序“的实现
现在移动客户端退出程序对话框退出越来越不流行了,都开始使用连续按两次来退出,即著名的“再按一次退出程序”模式.现在就看看怎么实现的吧. @SuppressLint("HandlerLeak& ...