Javaweb学习之JSON使用

学习目的

  1. 了解JSON的基础概念和作用
  2. 掌握JSON的基础使用
  3. 掌握JSON在实

一、JSON入门

  1. 概念
    JSON全称JavaScript Object Notation,意为JavaScript对象标记,简称JSON。JSON本质是一种标准的数据交换格式,是目前市场上非常流行,90%以上的系统采用的交换数据的格式(不同编程语言之间进行数据交换的格式)。JSON也可以称为无类型对象,轻量级、轻巧、体积小、易解析。

  2. 特点

  • JSON是一种标准的轻量级的数据交换格式,其体积小,易解析;
  • JSON在JS中以JS对象的形式存在;
  • java后端与浏览器前端进行数据交互的"工具"就是JSON,java获取的数据以字符串格式返回到浏览器,浏览器中的JS将字符串数据封装成JSON格式对象进行解析展示
  1. JSON与XML
    在实际的开发中有两种常用数据交换格式使用最多,其一是JSON,另一个是XML。
    XML体积较大,解析麻烦,但是有其优点是:语法严谨。(通常银行相关的系统之间进行数据交换使用XML)
// XML定义对象
<?xml version="1.0" encoding="UTF-8" ?> 
<students>
    <student sno="101">
        <sname>张三</sname>
        <sage>24</sage>
        <sex>男</sex>
    </student>
    <student sno="102">
        <sname>里斯</sname>
        <sage>21</sage>
        <sex>男</sex>
    </student>
    <student sno="103">
        <sname>王五</sname>
        <sage>20</sage>
        <sex>女</sex>
    </student>
</students>
  1. JSON的语法格式
// 创建JSON对象:JSON也可以称为无类型对象
var jsonObj = {
    "属性名" : 属性值,
    "属性名" : 属性值,
    "属性名" : 属性值,
    "属性名" : 属性值,
    ....
};
  1. 示例
// 定义传统JS对象
Student = function(sno,sname,sex){
        this.sno = sno;
        this.sname = sname;
        this.sex = sex;
}
// 创建对象
var stu = new Student("111","李四","男");
// 访问JS对象的属性
alert(stu.sno + "," + stu.sname + "," + stu.sex);

// 定义:JSON格式对象,对象定义与创建合并
 var studentObj = {
        "sno" : "110",
        "sname" : "张三",
        "sex" : "男"
  }
// 访问JSON对象的属性
alert(studentObj.sno + "," + studentObj.sname + "," + studentObj.sex);;
  1. JSON数组
    在目前的开发中,所有流行的编程语言用于数据交换的格式都是JSON。而在JAVA中,数据是以对象的形式存在的,当java中的多个对象返回给浏览器时,通常JS采用JSON数组的形式存储java返回的多个数据。
// []代表的是一个数组,{}代表的是一个JSON对象
var students = [
    {"sno":"110","sname":"张三","sex":"男"},
    {"sno":"120","sname":"李四","sex":"男"},
    {"sno":"130","sname":"王五","sex":"男"}
];

1.1 eval函数

  1. 描述
    eval函数是可以将JS中的字符串当做一段JS代码解释并执行的函数。

  2. 应用场景
    在java连接数据库进行查询数据之后,会将查询得到的数据在java程序中拼接成JSON格式的“字符串”,再将json格式的字符串返回到浏览器。因此java返回到浏览器上的仅仅是一个"JSON格式的字符串",而不是一个json对象,浏览器需要使用eval函数 将json格式的字符串转换成json对象才能完整的展示返回的数据。

  3. 格式

 window.eval("字符串" );
  1. 示例
// var i = 100;原本是普通字符串,但用在js中则是定义变量
window.eval("var i = 100;");
alert("i = " + i); // i = 100

// 将json格式的字符串转换成json对象,\为转义符
var fromJava = "{\"name\":\"zhangsan\",
                 \"password\":\"123\",
                 \"sex\":\"男\"}"; // java发给浏览器的json格式"字符串"
// 将以上json格式字符串转换成json对象
window.eval("var jsonObj = " + fromJava);
// 访问json对象,浏览器端执行输出
alert(jsonObj.name + "," + jsonObj.password);

1.2 JSON数据与表格

  1. 描述
    在JS中,java后台发送到前端浏览器的数据通常存储在JSON对象中,而JS常用的解析方式就是将JSON数据解析完成后 动态显示在<table>中。
  2. 示例
<script type="text/javascript">
            // json数据
            var data = {
                "total" : 4,
                "emps" : [
                    {"empno":7369,"ename":"SMITH","sal":800.0},
                    {"empno":7361,"ename":"SMITH2","sal":1800.0},
                    {"empno":7360,"ename":"SMITH3","sal":2800.0},
                    {"empno":7362,"ename":"SMITH4","sal":3800.0}
                ]
            };
            
            // 把JSON数据展示到table当中.
            window.onload = function(){
                // 当点击显示按钮后,获取JSON数据并显示
                var displayBtnElt = document.getElementById("displayBtn");
                displayBtnElt.onclick = function(){
                    // 将JSON数据用变量存储
                    // var emps = data.emps;
                    var html = "";
                    // 循环遍历JSON数组,得到JSON中的每一个具体对象
                    for(var i = 0; i < data.emps.length; i++){
                        var emp = data.emps[i];
                        // 字符串拼接,返回时在解析
                        html += "<tr>";
                        html += "<td>"+emp.empno+"</td>";
                        html += "<td>"+emp.ename+"</td>";
                        html += "<td>"+emp.sal+"</td>";
                        html += "</tr>";
                    }
                    // 往table标签的tbody中插入HTML代码
                    document.getElementById("emptbody").innerHTML = html;
                    // 往span中插入HTML代码
                    document.getElementById("count").innerHTML = data.total;
                }
            }
        </script>
        <input type="button" value="显示员工信息列表" id="displayBtn" />
        <h2>员工信息列表</h2>
        <hr>
        <table border="1px" width="50%">
            <tr>
                <th>员工编号</th>
                <th>员工名字</th>
                <th>员工薪资</th>
            </tr>
            <tbody id="emptbody">
                <!-- 固定写法,不易动态扩展
                <tr>
                    <td>7369</td>
                    <td>SMITH</td>
                    <td>800</td>
                </tr>
                <tr>
                    <td>7369</td>
                    <td>SMITH</td>
                    <td>800</td>
                </tr>
                -->
            </tbody>
        </table>
        总共<span id="count">0</span>条数

常见面试题

  1. 在JS当中:[]和{}有什么区别?
  • [] 描述的是数组对象。
  • {} 描述的是JSON格式对象。
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,682评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,277评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,083评论 0 355
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,763评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,785评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,624评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,358评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,261评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,722评论 1 315
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,900评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,030评论 1 350
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,737评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,360评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,941评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,057评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,237评论 3 371
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,976评论 2 355

推荐阅读更多精彩内容