源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

通过jsonp获取json数据实现AJAX跨域请求

  • 时间:2022-12-07 14:01 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:通过jsonp获取json数据实现AJAX跨域请求
AJAX([code]异步的 JavaScript 和 XML[/code])是用于创建快速动态网页的一种技术,它在不重新加载整个页面的情况下,与服务器交换数据并更新部分网页,ajax 使用[code]XMLHttpRequest[/code]对象在后台与服务器交换数据,XMLHttpRequest 是 AJAX 的基础,它允许客户端 JavaScript 通过 [code]HTTP[/code]请求连接到远程服务器。 但是,由于受到浏览器的限制,这种方法不可以进行跨域访问,如果使用这种方法进行跨域访问则会出现安全问题。不过,我们可以发现,在web页面跨域调用 js文件时,不会受到浏览器的限制,所以我们可以利用将远程服务器端的数据装入js格式的文件,然后再用来供客户端进行调用。 JSON([code]JavaScript 对象表示法[/code])是一种轻量级的文本数据交换格式,它具有自我描述性,易于理解。JSON 可通过 [code]JavaScript [/code]进行解析,JSON 数据可使用[code] AJAX [/code]进行传输。 JSON实例:
{
 "employees": [
 { "firstName":"Bill" , "lastName":"Gates" },
 { "firstName":"George" , "lastName":"Bush" },
 { "firstName":"Thomas" , "lastName":"Carter" }
 ]
 }
JSON 语法是 JavaScript 对象表示法语法的子集: 数据在[code]名称/值[/code]对中, 数据由[code]逗号[/code]分隔 ,[code]花括号[/code]保存对象, [code]方括号[/code]保存[code]数组[/code]。 JSON的特性 [list] [*]纯文本,易于跨平台传递[/*] [*]Javascript原生支持,后台语言几乎全部支持[/*] [*]使用轻量级的文本数据交换格式,适合在互联网中传递[/*] [*]比 XML 更小、更快,更易解析。[/*] [/list] 基于[code]JSON[/code]的这些特性,可以通过使服务器动态生成[code]JSON[/code]文件,然后将客户端需要的数据装入这个文件,再将该文件调回客户端供客户端使用。为了便于客户端使用数据,逐渐形成了一种非正式传输协议[code]JSONP[/code],该协议的一个要点就是允许用户传递一个[code]callback[/code]参数给服务端,然后服务端返回数据时会将这个[code]callback[/code]参数作为函数名来装入[code]JSON[/code]数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。 [b]如何使用JSONP[/b] 一种简单的方式就是使用jQuery来实现:
<!DOCTYPE html>
<html>
<head>
 <meta http-equiv="Content-Type" content="text/html;charset=utf-8">
 <title>test</title>
 <script type="text/javascript" src="http://apps.bdimg.com/libs/jquery/2.1.1/jquery.js"></script>
  <script type="text/javascript">
  $(document).ready(function(){ 
   
  $.ajax({
    type: "get",
    async: false,
    url: "http://encounter.christmas023.space/json.php?name=mavis&age=18",
    dataType: "jsonp",
    jsonp: "callback",//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback)
    jsonpCallback:"message",//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据
    success: function(json){
     alert('你的名字:' + json.name + ' 年龄: ' + json.age);
     
    },
    error: function(){
     alert('fail');
    }
   });
 
  });
  </script>
</head>
<body>

</body>
</html>

[list] [*][code]type[/code]:请求类型,GET 或 POST,默认为 GET;[/*] [*][code]async[/code]:true(异步)或 false(同步),默认情况下为true,同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行;[/*] [*][code]url[/code]:发送请求的地址(跨域请求时应为绝对地址);[/*] [*][code]dataType[/code]:指定服务器返回的数据类型;[/*] [*][code]jsonpCallback[/code]:自定义JSONP回调函数名称;[/*] [*][code]success[/code]:请求成功后回调函数;[/*] [*][code]error[/code]:请求失败时调用此方法。[/*] [/list] 运行结果: [img]http://files.jb51.net/file_images/article/201701/2017012215172415.png[/img] 服务器返回的数据类型: [img]http://files.jb51.net/file_images/article/201701/2017012215172416.png[/img] 返回一个指定函数名为[code]message[/code]的回调函数,函数里面包裹的数据为[code]JSON[/code]格式。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部