之前一直使用jQuery的ajax方法,导致自己对浏览器原生的XMLHttpRequest对象不是很熟悉,于是决定自己写下,以下是个人写的deom,发表一下,聊表纪念。

Ajax 和 jsonp 的javascript 实现:

/*!
* ajax.js
* © auth zernmal
* @ description XMLHttpRequest and Jsonp practice
*/ function ajax(url,options ){ var options = options || {} ,
method = options.method || "GET",
async = (typeof options.async !== "undefined") ? options.async : true ,
user = (typeof options.user !== "undefined") ? options.user : "" ,
pswd = (typeof options.pswd !== "undefined") ? options.pswd : "" ,
reciveType = options.reciveType || "string" ,
data = options.data || null ,
header = options.header || [],
callback = options.callback || function(){},
xhr = XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHTTP"); if(method=='GET' && data){ var dataStr = []; url = (url.indexOf("?")==-1) ? url + "?" : url + "&" ; for(var i in data){
dataStr.push( i + "=" + data[i]) ;
}
url += dataStr.join("&");
data = null;
}else if(data){
var form = new FormData();
for(var i in data){
form.append( i , data[i]);
}
data = form;
} xhr.onreadystatechange = function() { if (xhr.readyState == 4) {// 4 = "loaded"
if (xhr.status == 200) {// 200 = OK var responseData = null ; if(reciveType==="string"){
responseData = xhr.responseText;
}else if(reciveType === "json"){
responseData = xhr.responseText; if( false && JSON && JSON.parse) {
responseData = JSON.parse(responseData);
}else{
responseData = eval('('+responseData+')');
}
} options.callback && options.callback(responseData);
} else {
alert("Problem retrieving XML data");
}
}
}; xhr.open(method , url , async , user ,pswd); for(var i = header.length -1 ; i > 0 ; i--){
xhr.setRequestHeader(header[i].type, header[i].content);
} xhr.send(data);
} function jsonp(url , options){
var options = options || {} ,
script = document.createElement('script') ,
callback = options.callback || function(result){} ,
callbackName = 'myjsonpcall'+ (new Date()).getTime(),
data = options.data || {} ,
dataStr = []; for(var i in data){
dataStr.push( i + "=" + data[i]) ;
} if(url.indexOf("?")==-1){
url += "?"+ dataStr.join("&") +"&callback="+callbackName;
}else{
url += "&"+ dataStr.join("&") +"&callback="+callbackName;
} script.setAttribute('src', url);
window[callbackName] = callback ; // 把script标签加入head,此时调用开始
document.getElementsByTagName('head')[0].appendChild(script);
}

PHP服务端响应请求:

<?php

    $func = $_GET['func'];

    if(function_exists($func)){
$func();
}else{
funcNotExist();
} function funcNotExist(){
echo "function is not exist ! ";
} function returnJson(){
$lastName = $_GET['lastName'];
$firstName = $_GET['firstName']; echo json_encode(array('firstName'=>$firstName,'lastName'=>$lastName));
} function returnString(){
$lastName = $_GET['lastName'];
$firstName = $_GET['firstName'];
echo "the string you send is ".$lastName." ".$firstName;
} function postReturn(){
$lastName = $_POST['lastName'];
$firstName = $_POST['firstName'];
echo "the string you post is ".$lastName." ".$firstName;
} function jsonP(){ header('content-type: application/json; charset=utf-8');
$lastName = $_GET['lastName'];
$firstName = $_GET['firstName'];
$callbackFunc = isset($_GET['callback'])? htmlspecialchars($_GET['callback']):"callback";
$json = json_encode(array('firstName'=>$firstName,'lastName'=>$lastName)); echo "$callbackFunc($json)";
}

页面内调用方法:

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Ajax与Jsonp实践</title>
<script type="text/javascript" src="js/ajax.js"></script>
</head>
<body>
<script>
jsonp("/ajax.php?func=jsonP",{
callback : function(result){
console.log(result);
},
data : {
lastName : "zernmal" ,
firstName : "chen"
}
}); ajax("/ajax.php?func=returnJson",{
method : "GET",
callback : function(result){
console.log(result);
},
data : {
lastName : "zernmal" ,
firstName : "chen"
} ,
reciveType : "json"
});
</script>
</body>
</html>

以上只是简单实验,如有问题欢迎提出。

Ajax和Jsonp实践的更多相关文章

  1. json和jsonp的区别,ajax和jsonp的区别

    json和jsonp虽然只有一个字母的区别,但是它们之间扯不上关系. json是一种轻量级的数据交换格式. jsonp是一种跨域数据交互协议. json的优点:(1)基于纯文本传递极其简单,(2)轻量 ...

  2. 原生javascript封装ajax和jsonp

    在我们请求数据时,完成页面跨域,利用原生JS封装的ajax和jsonp: <!DOCTYPE html> <html lang="en"> <head ...

  3. ajax和jsonp的封装

    一直在用jQuery的ajax,跨域也是一直用的jQuery的jsonp,jQuery确实很方便,$.ajax({...})就可以搞定. 为了更好的理解ajax和jsonp,又重新看了下书,看了一些博 ...

  4. 针对AJAX与JSONP的异同

    针对AJAX与JSONP的异同       1.ajax和jsonp这两种技术在调用方式上“看起来”很像,目的也一样,都是请求一个url,然后把服务器返回的数据进行处理,因此jquery和ext等框架 ...

  5. ajax和jsonp使用总结

    前言:ajax和jsonp可以与后台通信,获取数据和信息,但是又不用刷新整个页面,实现页面的局部刷新. 一.ajax 定义:一种发送http请求与后台进行异步通讯的技术. 原理:实例化xmlhttp对 ...

  6. ajax 和jsonp 不是一码事

    由于Sencha Touch 2这种开发模式的特性,基本决定了它原生的数据交互行为几乎只能通过AJAX来实现. 当然了,通过调用强大的PhoneGap插件然后打包,你可以实现100%的Socket通讯 ...

  7. 关于jQuery.ajax()的jsonp碰上post详解

    前言 以前一直以为当$.ajax()的 dataType设置为jsonp时,其method(请求方法)无论怎么设置,都会变成get,直到前两天遇到了一个坑. 下面来一起看看详细的介绍: 关于跨域请求与 ...

  8. 原生 JavaScript 实现 AJAX、JSONP

    相信大多数前端开发者在需要与后端进行数据交互时,为了方便快捷,都会选择JQuery中封装的AJAX方法,但是有些时候,我们只需要JQuery的AJAX请求方法,而其他的功能用到的很少,这显然是没必要的 ...

  9. ajax和jsonp

    ajax和jsonp 前言:ajax和jsonp可以与后台通信,获取数据和信息,但是又不用刷新整个页面,实现页面的局部刷新. 一.ajax 定义:一种发送http请求与后台进行异步通讯的技术. 原理: ...

随机推荐

  1. java中的抽象方法与抽象类

    在继承时,会遇到一个问题.如果很多子类都要继承父类的一个方法,但是实现的逻辑都不一样. 这时候父类只提供了方法名,但是没有具体的方法体. 例如,男孩类和女孩类都继承人类这一个父类.人类有爱好这个方法, ...

  2. 《逐梦旅程 WINDOWS游戏编程之从零开始》笔记4——Direct3D编程基础

    第11章 Direct3D编程基础 2D游戏是贴图的艺术,3D游戏是渲染的艺术.这句话在我学过了之前的GDI编程之后,前一句算是有所体会,现在是来理解后一句的时候了. 安装DirectX SDK配置啥 ...

  3. hdu5731

    先求出不考虑分割线的n*m棋盘的覆盖方案数记为f[n][m] 然后枚举列分割线的状态(状压),计算此时不存在行分割线的方案数 求出这个我们就可以用容斥原理算出答案了 怎么算在列分割线确定的情况下,不存 ...

  4. 开始学习NodeJs, javascript, 算法

    我的技术路线是C.C++.C#.PHP,什么都做过,很杂,总想着该怎么继续下去. 最近突然发现了NodeJs,觉得很适合我. 学习环境定在了Ubuntu下,编辑软件选择了WebStorm7. 经过几天 ...

  5. git-全家桶

    关于git,网上一片赞美之声,我就不多说啥了,用过才知道,多好. 没有了解过的朋友,可以去大神廖雪峰传送门看看,我就是通过那里学会的基础,再次感谢大神无私的奉献!!! 下面分四个章节: 基础操作(其实 ...

  6. KVM-克隆和快照管理

    kvm 虚拟机有两部分组成:img镜像文件和xml配置文件 /etc/libvirt/qemu #xml配置文件目录,存在虚拟机所有的详细信息 1.kvm虚拟机克隆 克隆命令 virt-clone - ...

  7. SpringMVC一些功能

    1.日期格式转换 当页面提交日期格式时 默认的格式为2017/10/1 如果指定日期格式为2017-10-1 //初始化绑定日期格式--不定义初始化格式时只能默认用yyyy/MM/dd格式 @Init ...

  8. python中,将字符串由utf8转gbk

    uni_str = utf8_str.decode('utf-8'); gbk_str = uni_str.encode('gbk');

  9. 36、Flask实战第36天:客户端权限验证

    编辑cms_base.html <li><a href="#">{{ g.cms_user.username }}<span>[超级管理员]&l ...

  10. JZYZOJ 1375 双亲数 莫比乌斯反演

    http://172.20.6.3/Problem_Show.asp?id=1375 网上搜推理图. 有一段没有写莫比乌斯反演都快忘了..数学能力--,定理完全不会推,但是这道题整体来说应该是比较好写 ...