ajax请求JSON数据并解析

通常,从后台拿到的时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路径),而不是脚本的路径。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,269评论 19 139
  • Ajax的基本概念及使用 同步&异步 同步:必须等待前面的任务完成,才能继续后面的任务; 异步:不受当前主要任务的...
    magic_pill阅读 1,987评论 0 5
  • 我坚信一个人的性格形成是由幼儿时无数的伤反复被刻印而渐渐形成的。 我是被姥姥姥爷带大的孩子,知道9岁那...
    王静_我想静静阅读 298评论 0 2
  • 我在千峰绝壁行走 你在大海深处飘袂 我践踏坚冰 步履沉重的暗流 你是那 温柔的水啊 水粼粼的 摇动那载河之舟 我展...
    赛腾烟阅读 116评论 0 2
  • 母爱无言。 听过许多歌,看过许多故事,有一种最感动,也是最温馨,那就是母爱。 今天是我婚后回娘家的第一天。从...
    小汐0314阅读 180评论 0 0