html --- ajax --- javascript --- 简单的封装
Ajax的简单封装
Ajax的全称是AsynchronousJavaScriptAndXML
如有疑问请参考:http://zh.wikipedia.org/zh-cn/AJAX
以及传智播客的视频教程:http://java.itcast.cn/news/8308d118/740a/4dcd/8dbf/c73d2fe5bc60.shtml
其实已经有好多框架对它进行了封装,但是还是有好多时候用到自己封装的
透露一下,本人是宇多田光的听众之一哦!
封装后的代码如下:
文件路径:\web\AjaxRequest.js
/** * Created by yuki on 2014/5/13. * * 用法: 1.新建对象Ajax对象 2.设定带有一个XMLHttpRequest返回参数的回调函数 3.执行execute,传入请求方式,url,是否异步 * */ function Ajax() { this.xmlHttp = null; this.responseText = null; this.callback = null; } /** * 执行ajax */ Ajax.prototype.execute = function(method, url, async){ this.createXmlHttp(); this.sendUrl(method, url, async); this.getResponseText(); this.callback(); }; /** * 服务器返回服务器输出的纯文本数据 * @param embed */ Ajax.prototype.getResponseText = function(){ // 判断对象的状态 if (this.xmlHttp.readyState == 4) { // 判断http交互是否成功 if (this.xmlHttp.status == 200) { // 判断服务器返回的数据 // 获取服务器输出的纯文本数据 this.responseText = xmlHttp.responseText; } } }; /** * 发送url请求 * @param method 取值为GET或POST * @param url 要发送的url可以带请求参数 * @param async true表示异步,false表示同步 */ Ajax.prototype.sendUrl = function(method, url, async){ // 注册回调函数 this.xmlHttp.onreadystatechange = this.callback; // 第三个参数表示同步false或是异步true this.xmlHttp.open(method, url, async); // 发送数据,开始和服务器端交互 this.xmlHttp.send(); }; /** * 创建XMLHttpRequest */ Ajax.prototype.createXmlHttp = function(){ if (window.XMLHttpRequest) { this.xmlHttp = new XMLHttpRequest(); // 针对某些特定版本的Mozilla浏览器的BUG修正 if (this.xmlHttp.overrideMimeType) { this.xmlHttp.overrideMimeType('text/xml'); } } else if (window.ActiveXObject) { // 针对IE6, IE5.5, IE5 var activexName = ["MSXML2.XMLHTTP", "Microsoft.XMLHTTP"]; for (var i = 0; i < activexName.length; ++i) { try { // 取出控件名进行创建,如果创建成功就终止循环 this.xmlHttp = new ActiveXObject(activexName[i]); break; } catch (e) { // do nothing... } } } //确认XMLHttpRequest对象创建成功 if (!this.xmlHttp) { alert('XMLHttpRequest对象创建失败!'); } else { alert('XMLHttpRequest对象创建成功!'); } };
代码封装好了,怎么使用它呢?
看html页面的代码:
文件路径:\web\AjaxRequest.html
<!DOCTYPE html> <html> <head lang="en"> <meta charset="GBK"> <title>AjaxRequest</title> </head> <script src="AjaxRequest.js"></script> <body> <div id="div1" style="width:200px; height:200px; background-color: darkgoldenrod"></div> <script> var ajax = new Ajax(); ajax.callback = function(){ var responseText = this.responseText; var div1 = document.getElementById('div1'); div1.innerHTML = responseText; }; ajax.execute('GET', 'First.jsp', true); </script> </body> </html>
它是要访问服务器的,让jsp为它提供服务吧
文件路径:\web\First.jsp
<%-- Created by IntelliJ IDEA. User: yuki Date: 2014/5/13 Time: 23:07 To change this template use File | Settings | File Templates. --%> <%@ page contentType="text/html;charset=UTF-8" language="java" %> <html> <head> <title>HI</title> </head> <body> <h1>Hello Ajax!</h1> Date = <%= new java.util.Date() %> <br> </body> </html>
这样,Ajax的技术就可以是在页面不刷新的情况下,得到服务器的输出了
下面是结果:
更多好文请关注我的博客:
http://www.cnblogs.com/kodoyang/
html --- ajax --- javascript --- 简单的封装的更多相关文章
- 用javascript简单封装AJAX
1.创建一个AJAX引擎对象 var CreateAjax = function () { var xhr = null; if (window.XMLHttpRequest) { //非IE游览器 ...
- ajax的三次封装简单概况
原生ajax: readyState 准备状态 status 页面状态 ...
- 第107天:Ajax 实现简单的登录效果
使用 Ajax 实现简单的登录效果 Ajax是一项使局部网页请求服务器信息,而不需整体刷新网页内容的异步更新技术.这使得向服务器请求的数据量大大减少,而且不会因局部的请求失败而影响到整体网页的加载. ...
- 第一百六十一节,封装库--JavaScript,完整封装库文件
封装库--JavaScript,完整封装库文件 /** *feng_zhuang_ku_1.0版本,js封装库,2016/12/29日:林贵秀 **/ /** 前台调用 * 每次调用$()创建库对象, ...
- Django ajax的简单使用、自定义分页器
一. ajax初识 1. 前后端传输数据编码格式contentType 使用form表单向后端提交数据时,必须将form表单的method由默认的get改为post,如果提交的数据中包含文件,还要将f ...
- 我自己的Javascript 库,封装了一些常用函数 Kingwell.js
我自己的Javascript 库,封装了一些常用函数 Kingwell.js 博客分类: Javascript javascript 库javascript库 现在Javascript库海量,流行的 ...
- Ajax+Ashx实现以及封装成控件的实现
asp.net 后台多线程异步处理时的 进度条实现一(Ajax+Ashx实现以及封装成控件的实现) 工作好长时间了,这期间许多功能也写成了不少的控件来使用,但是,都只是为了代码的结构清析一些而已.而这 ...
- MVC3.0+knockout.js+Ajax 实现简单的增删改查
MVC3.0+knockout.js+Ajax 实现简单的增删改查 自从到北京入职以来就再也没有接触MVC,很多都已经淡忘了,最近一直在看knockout.js 和webAPI,本来打算采用MVC+k ...
- php+jquery+ajax+json简单小例子
直接贴代码: <html> <title>php+jquery+ajax+json简单小例子</title> <?php header("Conte ...
随机推荐
- SparkContext和RDD
SparkContext.scala实现了一个SparkContext的class和object,SparkContext类似Spark的入口,负责连接Spark集群,创建RDD,累积量和广播量等. ...
- Matlab绘图高级部分
图形是呈现数据的一种直观方式,在用Matlab进行数据处理和计算后,我们一般都会以图形的形式将结果呈现出来.尤其在论文的撰写中,优雅的图形无疑会为文章加分.本篇文章非完全原创,我的工作就是把见到的Ma ...
- python操作json
概念 序列化(Serialization):将对象的状态信息转换为可以存储或可以通过网络传输的过程,传输的格式可以是JSON.XML等.反序列化就是从存储区域(JSON,XML)读取反序列化对象的状态 ...
- 重置mysql的root密码
由于本人记性比较差,今天的mysql的root密码又忘记了,咋办呢?只能重置root的密码了.具体的操作步骤如下: 1. 首先检查mysql服务是否启动,若已启动则先将其停止服务,可在开始菜单的运行, ...
- Go语言学习笔记一(语法篇)
国庆节七天假期,这段时间刚好项目那边催的不是很紧,基本上每天都是白天重构一下项目代码,晚上自己学习.(大概是因为容总那边的人都去度假了把项目进度放慢了吧.这两天“彩虹”姐姐也来凑热闹,据说还是直接从澳 ...
- Ubuntu 14.04怎样升级到Ubuntu 14.10
Ubuntu 14.04怎样升级到Ubuntu 14.10 Ubuntu 14.10 Utopic Unicorn 将在10月23日正式发布,9月25日最终测试版本已经发布,Ubuntu 14 ...
- JavaScript 中 2个等号(==)和 3个等号(===)之间的区别
JavaScript(JS)中有3个和等号(=)相关的操作符:赋值运算符(=).等于(==).恒等于(===). 赋值运算符不多说了. 这里说说等于和恒等于. ==,等于:两边值类型不同的时候,会自动 ...
- HDU 1941 Hide and Seek(离散化+树状数组)
题目链接:http://61.187.179.132/JudgeOnline/problem.php?id=1941 题意:给出平面上n个点,找出一点p,使得距离p最近和最远的点的距离之差最小.输出这 ...
- LEFT JOIN、Right、Full后ON和WHERE的区别
今天在工作的时候碰到了一个问题,A表B表left join后在on后面关于A表的条件过滤语句没起到我想要的过滤作用,还是对左连接等理解的不够呀. SELECT * FROM student; SELE ...
- staging server, source congtrol, deply workflow using git
web项目开发中,有三个实践对于项目成功是非常重要的: 1. staging servers 2. Version control workflows 3. Tested, repeatable de ...