美文网首页
ajax请求JSON数据并解析

ajax请求JSON数据并解析

作者: 丶灰太狼他叔 | 来源:发表于2018-01-01 22:06 被阅读33次

通常,从后台拿到的时JSON字符串。所以用JSON.parse来转为JSON对象,不建议使用eval()函数,因为eval()接受任意的字符串,并当作JavaScript代码来处理,这个机制已经有安全隐患了。

  • ajax是局部刷新页面,所以页面并不会刷新。判断是不是用的ajax来做的可以点击的时候看看页面是否刷新就可以了

用到ajax所以需要一个本地的服务器环境,file协议是不允许的。之前想用node的express来搭建一个本地的服务器,但是总是拿不到json。最后也没有找到原因。所以干脆直接用hbuilder直接打开(webstorm也是可以的),它是内置了本地服务器环境的,简单粗暴。
简单的JSON数据:

[{
        "MVP":"Stephen Curry",
        "position":"Point Guard",
        "number":"30",
        "team":"Golden State Warriors"
    },{
        "FMVP":"Lebron James",
        "position":"Small Forward",
        "number":"23",
        "team":"Cleveland Cavaliers"
    }] 

HTML代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title>ajax</title>
    <script  src="http://libs.baidu.com/jquery/1.7.2/jquery.min.js"></script>
    <style>
        .btn {
            background: blue;
        }
    </style>
</head>
<body>
    <button class="btn1">按钮1</button>
    <button class="btn2">按钮2</button>
    <ul></ul>
</body>
<script type="text/javascript">
    $(function () {
        $('button').click(function () {
            $('button').removeClass('btn');
            $(this).addClass('btn');
        });
        $('.btn1').click(function () {
            $.getJSON('./one.json',function (res) {
                console.log(res);
                //console.log(typeof res);//object
                $.each(res,function (index,item) {
                    console.log(index,item);
                    $('ul').append('<li>' + item.position +'</li>')
                });
            });

        });
        $('.btn2').click(function () {
            $.getJSON('./two.json',function (res) {
                //console.log(typeof res);//object
                $.each(res,function (index,item) {
                    console.log(index,item);
                    $('ul').append('<li>' + item.team +'</li>')
                });
            });

        });
    })
</script>
</html>

each方法遍历数组的时候:第一个参数为这个数组对象,函数的参数分别为下标和对应该下标的对象

  • 这里为了省事所以只是简单的拿到了数据,解析了一个属性放了上去
  • 后台一般返回的为一个JSON字符串,所以要用JSON.parse()转为一个JSON对象。
  • 一般遍历是用each方法来做的,当然用for循环也是可以的。
    最后,上个效果图


    ajax.png

最后还有一个需要注意的问题就是,JSON的路径时相对于HTML的,而不是这个JS的路径;因为脚本执行时的base路径是你的document路径(既HTML路径),而不是脚本的路径。

相关文章

  • SSM框架的(CRUD)_查询_构建员工列表11

    1、重新改造index.jsp页面,通过发送ajax请求返回json格式数据信息并解析json数据渲染页面。

  • ajax请求JSON数据并解析

    通常,从后台拿到的时JSON字符串。所以用JSON.parse来转为JSON对象,不建议使用eval()函数,因为...

  • ajax介绍, 模板, 文件上传, json格式数据

    目录: ajax介绍 ajax模板 文件上传 基于ajax提交json格式数据 重点:设置请求与响应回来的解析编码...

  • 五、Groovy语法(五)json、xml解析

    Groovy数据解析 一、json解析 请求网络数据并解析 二、xml解析 groovy解析xml数据 groov...

  • Python爬取招聘信息并对岗位分析报告

    本文目标 获取 Ajax 请求,解析 JSON 中所需字段 数据保存到 Excel 中 数据保存到 MySQL, ...

  • ajax

    Ajax 1 - 请求纯文本 Ajax 2 - 请求JSON数据 Ajax 3 - 请求Github接口 Ajax...

  • Vue.js 读取json

    Vue.js 读取json 这里使用两种方法获取json 并讲数据显示到页面上 使用 ajax 请求到json数据...

  • 前后端交互

    ajax 返回字符串类型 返回json格式数据类型 不同的是,需要解析 请求方式 GET 和 POST 请求 案例...

  • 网络

    NSURLConnection NSURLSession 普通网络请求 JSON数据解析 JSON序列化 数据解析...

  • ajax与jsonp、jsonp

    轮播图 json 数据格式 ajax与jsonp ajax是获取数据的 get请求 post请求 url:"js/...

网友评论

      本文标题:ajax请求JSON数据并解析

      本文链接:https://www.haomeiwen.com/subject/lldxnxtx.html