这里有新鲜出炉的 Javascript 教程,程序狗速度看过来!
Javascript 是一种由 Netscape 的 LiveScript 发展而来的原型化继承的基于对象的动态类型的区分大小写的客户端脚本语言,主要目的是为了解决服务器端语言,比如 Perl,遗留的速度问题,为客户提供更流畅的浏览效果。
这篇文章主要介绍了 javascript 实现简单的 ajax 封装功能, 结合实例形式分析了 ajax 基本功能与操作实现技巧, 需要的朋友可以参考下
本文实例讲述了 javascript 实现简单的 ajax 功能封装。分享给大家供大家参考,具体如下:
- function ajax(obj){
- var xhr = (function (){//获取xhr对象,为了兼容ie6所以进行了重新封装
- if(typeof XMLHttpRequest !='undefined') {
- return new XMLHttpRequest();
- }else if(typeof ActiveXObject !='undefined') {
- var version = [
- 'MSXML2.XMLHttp6.0',
- 'MSXML2.XMLHttp3.0',
- 'MSXML2.XMLHttp'
- ]
- for(var i in version) {
- try{
- return new ActiveXObject(version[i]);
- break;
- }catch(e){
- //捕获错误进行然后跳出继续循环
- }
- }
- }else{
- throw new Error("您的系统或浏览器不支持XHR对象!");
- }
- })();//获取xhr对象
- //默认true开启异步(异步和同步的主要区别是异步在请求的时候后面的脚本可以继续运行,同步的话必须运行完ajax然后才能运行其后面的脚本)
- if(obj.async === true) {
- xhr.onreadystatechange = function() {
- if(xhr.readyState ==4) {
- callback(xhr.responseText);
- }
- }
- }
- var arr=[] ;
- for(var i in obj.data) {arr.push(encodeURIComponent(i)+'='+encodeURIComponent(obj.data[i]));}
- obj.data = arr.join('&'); //这一步要注意一下,不管是get/post 方式提交都必须要对传进来的obj.data进行格式化 最后转化成的格式name=zhang&age=26&wedding=no
- if(obj.method === 'get') {//通过get方式请求的
- obj.url = obj.url.indexOf('?') ==-1 ? obj.url+'?rand='+Math.random()+'&'+obj.data : obj.url+'rand='+Math.random()+'&'+obj.data;
- xhr.open(obj.method,obj.url,obj.async);
- xhr.send(null);
- }
- if(obj.method === 'post') {//通过post方式请求的
- obj.url =obj.url+'?rand='+Math.random();
- xhr.open(obj.method,obj.url,obj.async);
- xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');//这是对请求头部的类型重设,post的请求必须要重设;
- xhr.send(obj.data);
- }
- //false开启同步
- if(obj.async === false) {callback(xhr.responseText);}
- function callback (returnTxt) {
- if(xhr.status == 200){
- obj.success(returnTxt);
- }else {
- alert('获取数据错误!错误代号:' + xhr.status + ',错误信息:' + xhr.statusText);
- }
- }
- }
希望本文所述对大家 JavaScript 程序设计有所帮助。
来源: http://www.phperz.com/article/17/0601/329061.html