快捷搜索:   nginx

JQuery使用getJSON方法获取json数据方法完整示例 ajax无刷新获取JSON

jQuery内置的getJSON方法可以方便的获取后端输出的JSON数据,并无刷新返回

这里实例讲述了jQuery使用getJSON方法获取后端PHP返回的json数据。具体方法如下:

假设后端PHP返回的JSON代码如下:

后端生成JSON的程序json.php

[
  {
    "name":"吴者然",
    "sex":"男",
    "email":"[email protected]"
  },
  {
    "name":"吴中者",
    "sex":"男",
    "email":"[email protected]"
  },
  {
    "name":"何开",
    "sex":"女",
    "email":"[email protected]"
  }
]


前段显示JSON结果的页面demo.html

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>getJSON获取数据</title>
<script type="text/javascript" src="js/jquery-1.10.1.min.js"></script>
<style type="text/css">
#divframe {
  border: 1px solid #999;
  width: 500px;
  margin: 0 auto;
}
.loadTitle {
  background: #CCC;
  height: 30px;
}
</style>
<script type="text/javascript">
$(function(){
  $("#btn").click(function(){
    $.getJSON("js/demo.js",function(data){
      var $jsontip = $("#jsonTip");
      var strHtml = "123";//存储数据的变量
      $jsontip.empty();//清空内容
      $.each(data,function(infoIndex,info){
        strHtml += "姓名:"+info["name"]+"<br>";
        strHtml += "性别:"+info["sex"]+"<br>";
        strHtml += "邮箱:"+info["email"]+"<br>";
        strHtml += "<hr>"
      })
      $jsontip.html(strHtml);//显示处理后的数据
    })
  })
})
</script>
</head>
<body>
<div id="divframe">
  <div class="loadTitle">
    <input type="button" value="获取数据" id="btn"/>
  </div>
  <div id="jsonTip"> </div>
</div>
</body>
</html>

这里使用了$("#btn").click(function()的方法,获取btn这个ID的按钮点击行为,如果不需要点击,只要进页面就执行输出,可以改成:

<script type="text/javascript">
$(function(){

    $.getJSON("js/demo.js",function(data){
      var $jsontip = $("#jsonTip");
      var strHtml = "123";//存储数据的变量
      $jsontip.empty();//清空内容
      $.each(data,function(infoIndex,info){
        strHtml += "姓名:"+info["name"]+"<br>";
        strHtml += "性别:"+info["sex"]+"<br>";
        strHtml += "邮箱:"+info["email"]+"<br>";
        strHtml += "<hr>"
      })
      $jsontip.html(strHtml);//显示处理后的数据

  })
})
</script>


效果图如下:

这里把 JSON 的后缀名改为 JS,放在 WEB 容器中也可以正常读取,还可以跨域调用。


顶(6)
踩(0)

您可能还会对下面的文章感兴趣:

最新评论