ajax jsonp 原理 以及对数据的处理
ajax请求
var xmlhttp;
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.onreadystatechange=function()
{
&& xmlhttp.status==)
{
document.getElementById("myDiv").innerHTML=xmlhttp.responseText;
}
}
xmlhttp.open("GET","/ajax/test1.txt",true);
xmlhttp.send();
jsonp请求原理
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
</head>
<body>
<script>
function fn(data){
alert(data)
};
</script>
<script src="data.js"></script>
</body>
</html>
data.js 的内容是 fn([1,2,3,4,5])
输出结果:

实例:
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<script src="jquery1.8.3.min.js"></script>
</head>
<body>
<dl id="Dl1">
</dl>
<script>
function fn(data) {
var oDl1 = $('#Dl1');
var html = '';
$.each(data,function(index,content){
$.each(content,function(i,c){
html += '<dt>'+c['title']+'</dt>';
html += '<dd>'+c['summary']+'</dd>';
})
})
oDl1.html(html)
};
var oScript = document.createElement('script');
oScript.src = 'https://api.douban.com/v2/book/search?q=javascript&count=10&callback=fn';
document.body.appendChild(oScript);
document.body.removeChild(oScript);
</script>
</body>
</html>
百度输入框实例:http://457375608.github.io/liujin/jsonp/百度输入框.html
豆瓣搜索框实例:http://457375608.github.io/liujin/jsonp/豆瓣输入框.html
处理数据:
//遍历数组 第一个参数是索引 第二个是内容
$.each( [0,1,2], function(i, n){
console.log( "索引:" + i + " 内容: " + n );
});
//遍历对象 第一个参数是key 第二个参数value
$.each( {name:"liujin","age":"24","sex":"boy"}, function(i, n){
console.log( "key:"+ i + " value: " + n );
});

//实例一
$(function(){
var data={
"HTML":["html 1","html 2","html 3"] ,
"CSS":["css 1","css 2","css 3"] ,
"JAVASCRIPT":["javascript 1","javascript 2","javascript 3"]
};
document.write("<dl>")
$.each(data,function(index,content){
document.write("<dt>"+index+"</dt>")
$.each(content,function(i,c){
document.write("<dd>"+c+"</dd>")
})
})
document.write("</dl>")
})
//实例二
var data=[{
小学生:[
{name:'小学生一 ',sex:'boy ',age:24},
{name:'小学生二 ',sex:'boy ',age:24},
{name:'小学生三 ',sex:'boy ',age:24}
]
},
{
中学生:[
{name:'中学生一 ',sex:'girl ',age:24},
{name:'中学生二 ',sex:'girl ',age:24},
{name:'中学生三 ',sex:'girl ',age:24}
]
},
{
大学生:[
{name:'大学生一 ',sex:'boy ',age:24},
{name:'大学生二 ',sex:'boy ',age:24},
{name:'大学生三 ',sex:'boy ',age:24}
]
}];
//jQuery实现
$.each(data,function(index,con1){
$.each(con1,function(index,con2){
document.write(index+"<br>");
$.each(con2,function(index,con3){
document.write(con3.name+" "+con3.sex+" "+con3.age+"<br>")
})
})
})
//js实现 for...in遍历对象 for遍历数组
for(var i=0;i<data.length;i++){ //遍历年级所在对象(数组)
for(var x in data[i]){ //输出对象属性名(对象)
document.write(x+"<br>");
for(var a=0;a<data[i][x].length;a++){ //遍历对象属性值(数组)
document.write(data[i][x][a].name+""+data[i][x][a].sex+""+data[i][x][a].age+"<br>")
}
}
}
//$("").load(url,data,function(response,status,xhr))
$("#result").load("ajax/test.html"); //加载整个页面
$("#result").load("ajax/test.html #container"); //加载页面的一部分
$("#result").load("ajax/test.html", function() { //回调函数
alert("Load was performed.");
});
//$.get(URL,function(数据,状态){});
//等价于
$.ajax({
type:GET,
url: url,
success: function(data,status){
}
});
//$.post(url,data,function(数据,状态){})
//等价于
$.ajax({
type: 'POST',
url: url,
data: {key1:value1,key2:value2},
success:function(data,status){
}
});
$.ajax({
url:"", //string 请求地址
type:"", //string 请求方式(post/get)
timeout:"", //number 超时时间(毫秒)
data:"", //json 发送数据 {key:valut,key:value}
dataType:"", //string xml,html,script,json,text
beforeSent:"", //function 请求之前 function(XMLHttpRequest)
complete:"", //function 请求完成 function(XMLHttpRequest,textStatus)
seccess:"", //function 请求成功 function(data,textStatus)
error:"" //function 请求失败 function(XMLHttpRequest,textStatus,errorThrown)
});
//实例
$.ajax({
type: "GET",
url: "test.json",
dataType: "json",
success : function(data){
$('#resText').empty();
var html = '';
$.each( data , function(Index, comment) { //处理json
html += '<div class="comment"><h6>' + comment['username'] + ':</h6><p class="para">' + comment['content'] + '</p></div>';
})
$('#resText').html(html);
}
});
name:小学生一 sex:boy age:24 name:小学生二 sex:boy age:24 name:小学生三 sex:boy age:24 name:中学生一 sex:girl age:24 name:中学生二 sex:girl age:24 name:中学生三 sex:girl age:24 name:大学生一 sex:boy age:24 name:大学生二 sex:boy age:24 name:大学生三 sex:boy age:24
$.each(data,function(i,n){
$.each(n,function(k,v){
$.each(v,function(i,n){
$.each(n,function(a,b){
document.write(a+':'+b)
})
document.write('<br>')
})
})
})
ajax jsonp 原理 以及对数据的处理的更多相关文章
- Ajax & JSONP 原理
Ajax & JSONP 原理 AJAX不是JavaScript的规范,它只是一个哥们"发明"的缩写:Asynchronous JavaScript and XML,意思就 ...
- jQuery-1.9.1源码分析系列(十六)ajax——jsonp原理
json jsonp 类型 "json": 把响应的结果当作 JSON 执行,并返回一个JavaScript对象.如果指定的是json,响应结果作为一个对象,在传递给成功处理函数 ...
- jQuery源码分析系列(35) : Ajax - jsonp的实现与原理
ajax的核心是通过XmlHttpRequest获取非本页内容,而jsonp的核心则是动态添加<script>标签来调用服务器提供的js脚本 json核心就是:允许用户传递一个callba ...
- Ajax跨域:Jsonp原理解析
推荐先看下这篇文章:JS跨域(ajax跨域.iframe跨域)解决方法及原理详解(jsonp) JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重 ...
- JQuery实现Ajax跨域访问--Jsonp原理
JavaScript是一种在Web开发中经常使用的前端动态脚本技术.在JavaScript中,有一个很重要的安全性限制,被称为“Same-Origin Policy”(同源策略).这一策略对于Java ...
- ajax工作原理及jsonp跨域详解
一.Ajax简介 ajax = 异步 JavaScript 和 XML. ajax是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术.我们知道,传统的网页(不使用ajax)如果需要更新内容, ...
- ajax工作原理,Jsonp原理
Ajax工作原理是 相当于在用户和服务器之间加了-个中间层(AJAX引擎),使用户操作与服务器响应异步化. 对于用户请求ajax引擎会做一些数据验证和数据处理,不是所有请求都提交给服务器,当需要从服务 ...
- AJAX JSONP源码实现(原理解析)
关于JSONP以及跨域问题,请自行搜索. 本文重点给出AJAX JSONP的模拟实现代码,代码中JSONP的基本原理也一目了然. <html xmlns="http://www.w3. ...
- jsonp跨域获取数据小解
jsonp跨域获取数据小解 由于浏览器有同源策略,所以要想获取非同源(协议,域名,端口三者有一不同都算非同源)的页面的数据,就得进行跨域 (1) jsonp原理 由于script标签的src属性可以访 ...
随机推荐
- mac下的改装人生——关于机械键盘
这几天好像弄了很多关于机械键盘的东西,我自己的这块键盘也已经慢慢熟悉了,感觉打字超级爽哈,然后看了很多网上关于机械键盘的帖子,也看了很多教程,在Amazon和Taobao看了很多键盘的价位,前几天还试 ...
- poj 1106 Transmitters (枚举+叉积运用)
题目链接:http://poj.org/problem?id=1106 算法思路:由于圆心和半径都确定,又是180度,这里枚举过一点的直径,求出这个直径的一个在圆上的端点,就可以用叉积的大于,等于,小 ...
- 深入分析Java的序列化与反序列化
序列化是一种对象持久化的手段.普遍应用在网络传输.RMI等场景中.本文通过分析ArrayList的序列化来介绍Java序列化的相关内容.主要涉及到以下几个问题: 怎么实现Java的序列化 为什么实现了 ...
- Docker官方文档翻译之入门
转自:http://www.cnblogs.com/vikings-blog/p/3958091.html Docker学习总结之docker入门 Understanding Docker 以下均翻译 ...
- 【转】javascript日期操作详解(脚本之家整理)
时间对象是一个我们经常要用到的对象,无论是做时间输出.时间判断等操作时都与这个对象离不开.除开JavaScript中的时间对象外,在VbScript中也有许多的时间对象,而且非常好用.下面还是按照我们 ...
- 程序员取悦女朋友的正确姿势---Tips(iOS美容篇)
前言 女孩子都喜欢用美图工具进行图片美容,近来无事时,特意为某人写了个自定义图片滤镜生成器,安装到手机即可完成自定义滤镜渲染照片.app独一无二,虽简亦繁. JH定律:魔镜:最漂亮的女人是你老婆魔镜: ...
- 有关Transaction not successfully started问题解决的方法
我的项目配置:struts2+hibernate3.3+spring3.2.5 主要问题:在进行更新和提交操作时出现下面异常 org.springframework.transaction.Trans ...
- SQL Server 2012 sa 用户登录 18456 错误
近期想研究下SQL SERVER2012 Enterprise版本号的数据库,听说功能非常强大. 我是在win7上安装的,安装的过程非常顺利,我在用"Windows 身份验证"时, ...
- MySQL 的 read_buffer_size 参数是如何影响写缓冲和写性能的?
Each thread // that does a sequential scan . The value of this variable should be a multiple of 4KB. ...
- easyui总结
1.设置一个区域可拖动的第一种方法直接用html<div id="dd" style="width:100px;height:100px;">< ...