实例解析java + jQuery + json工作过程(获取JSON数据)

简介:

前天刚刚写的一篇关于《实例解析java + ajax(jQuery) + json工作过程(登录)》的文章引起了网友们的关注和好评,

自从本站的账务管理系统(个人版)开源 以后很多网友询问系统的实现方式,我一一解释……,为此今天写文章详细讲解系统功能的实现细节。

以本站的开源项目账务管理系统的“债务人”模块为例子讲解

一、效果预览

债务人详细页面效果预览

二、实现方式


基本思想就是绑定列表中的人员名称触发事件,获得当前人员的ID发送ajax请求到后台,后台根据ID查询详细信息,返回JSON数据结果至前台,前台通过对话框组件显示人员详细


1、绑定click事件到列表的人员名称 在项目中的iouser/js/iouser.js文件中有这样一个方法:


/**
 * 点击名称弹出详细
 */
function regShowDetail() {
    $("span[name=iouid]").unbind('click').bind('click', function(){
        showDetail($(this).parent().parent().find('input[name=chk]').val());
    });
}


通过regShowDetail绑定了点击人员时执行showDetail的事件,


$(this).parent().parent().find('input[name=chk]').val()
//上面这句话就是获得列表左侧的复选框的value值以便传送给后台


  • 下面介绍一下showDetail方法的功能实现:

 * 查看用户详细资料
 * @param {} userId 用户ID
 */
function showDetail(userId) {
    // 创建一个对话框组件
    var dialog = $.weeboxs.open('showDetail.html', {
        title: '正在加载用户信息……',
        contentType: 'ajax',
        width: 600,
        height: 350,
        animate: true,
        clickClose: false,
        type: 'wee',
        showOk: false,
        cancelBtnName: '关 闭',
        onopen: innerShowDetail
    });

    //内部函数,实现债务人详细信息的载入、设置值
    function innerShowDetail() {
        // 获得JSON格式的数据
        $.getJSON('load.do',{id : userId}, function(json) {
            // 根据key设置value
            for (key in json) {
                if(key == 'id'){
                    $('#detailDiv #' + key).val(json[key]);
                } else {
                    if(json[key] == ''){
                        // 没有值设置为空
                        $('#detailDiv #' + key).html('?');
                    } else if(key == 'sex'){
                        $('#detailDiv #' + key).html(json[key] == '0' ? '女' : '男');
                    } else if(key == 'group'){
                        if(json[key] != null) {
                            $('#detailDiv #' + key).html(json[key]['groupName']);
                        }
                    } else {
                        $('#detailDiv #' + key).html(json[key]);
                    }
                }
            }

            //设置对话框标题和内容
            $('#detailDiv').removeAttr('class');
            dialog.setTitle('查看人员[' + json['userName'] + ']详细资料');
            dialog.setContent($('#detailDiv').html());
        });
    }
}


  • showDetail方法首先打开一个对话框组件 加载一个静态的模板showDetail.html
    • 文件中的ID都是根据信息点命名的,这样便于通过ID设置值
  • 通过路径load.do 请求后台查询人员详细,后台处理类为net.yanhl.iouser.action.IOUserAction的loadUser()方法,代码请点击这里查看
    • 怎么查询一个POJO对象就介绍了,重点说明怎么返回JSON格式的数据
    • 这里还是使用java语言使用的JSON工具json-lib,关于json-lib的资料上篇文章也已介绍,这里不再重复;

      // 获取一个Iouser对象,包含债务人的信息
      Iouser user = (Iouser) getBaseManager().get(Iouser.class, iouserId);
      
      //使用json-lib工具把一个POJO对象解析为一个JSON格式数据
      JSONObject jsonObject = JSONObject.fromObject(user, config);
      
      //向前台发送结果集
      print(response, jsonObject.toString());


      最中返回的结果集如下:

      {
      "age" : 56,
      "companyAddress" : "32",
      "companyName" : "未知",
      "companyPhone" : "--",
      "companyZip" : "",
      "createDate" : null,
      "creatorId" : 1,
      "group" : {
      "childSize" : 0,
      "createDate" : {
      "date" : 27,
      "day" : 6,
      "hours" : 0,
      "minutes" : 0,
      "month" : 11,
      "nanos" : 0,
      "seconds" : 0,
      "time" : 1230307200000,
      "timezoneOffset" : -480,
      "year" : 108
      },
      "creatorId" : 1,
      "groupName" : "商务",
      "id" : 33,
      "orderNum" : 0,
      "remark" : ""
      },
      "homeAddress" : "香港九龙",
      "homePhone" : "",
      "homeZip" : "",
      "id" : 12,
      "mobilePhone" : "15856453456",
      "orderNum" : 0,
      "remark" : "香港富豪",
      "sex" : "1",
      "userName" : "李嘉诚"
      }


  • 前台获得了结果集之后就可以根据key获得value来设置详细页面的内容了,代码如下:

    for (key in json) {
        if(key == 'id'){
            $('#detailDiv #' + key).val(json[key]);
        } else {
            $('#detailDiv #' + key).val(json[key]);
        }
    }


    至此就是我们刚刚看到的效果了,是不是很简单O(∩_∩)O~
相关文章
|
6月前
|
JSON 定位技术 PHP
PHP技巧:解析JSON及提取数据
这就是在PHP世界里探索JSON数据的艺术。这场狩猎不仅仅是为了获得数据,而是一种透彻理解数据结构的行动,让数据在你的编码海洋中畅游。通过这次冒险,你已经掌握了打开数据宝箱的钥匙。紧握它,让你在编程世界中随心所欲地航行。
233 67
|
3月前
|
存储 Java 关系型数据库
Java 项目实战基于面向对象思想的汽车租赁系统开发实例 汽车租赁系统 Java 面向对象项目实战
本文介绍基于Java面向对象编程的汽车租赁系统技术方案与应用实例,涵盖系统功能需求分析、类设计、数据库设计及具体代码实现,帮助开发者掌握Java在实际项目中的应用。
145 0
|
5月前
|
安全 Java 测试技术
Java 大学期末实操项目在线图书管理系统开发实例及关键技术解析实操项目
本项目基于Spring Boot 3.0与Java 17,实现在线图书管理系统,涵盖CRUD操作、RESTful API、安全认证及单元测试,助力学生掌握现代Java开发核心技能。
275 0
|
6月前
|
人工智能 Java 开发者
【Java实例-简易计算机】使用Java实现简单的计算机案例
一个简单的Java案例——“简易计算器”,帮助编程新手快速上手。通过实现用户输入、基本逻辑运算和结果输出,学习者可以掌握变量声明、Scanner对象使用、控制流语句等关键知识点。文章分为设计思路、关键知识点、完整代码和测试运行四个部分。
212 9
【Java实例-简易计算机】使用Java实现简单的计算机案例
|
7月前
|
Java 测试技术 项目管理
【JavaEE】从 0 到 1 掌握 Maven 构建 Java 项目核心技巧 解锁 Java 项目高效管理实用实例
本文从Maven基础概念讲起,涵盖安装配置、核心概念(如POM与依赖管理)及优化技巧。结合Java Web项目实例,演示如何用Maven构建和管理项目,解决常见问题,助你高效掌握这一强大工具,提升Java开发与项目管理能力。适合初学者及进阶开发者学习。资源链接:[点此获取](https://pan.quark.cn/s/14fcf913bae6)。
268 6
|
6月前
|
Java 开发者
【Java实例-神秘年龄】用Java挑战你的直觉
我们一起走进这款款简单却充满趣味的Java小游戏——“神秘年龄”。这款游戏不仅适合编程初学者作为练习项目,也能为有一定基础的开发者提供一个轻松的编程小憩。
87 0
【Java实例-神秘年龄】用Java挑战你的直觉
|
6月前
|
Java 开发者
【Java实例-神秘硬币】用Java投掷你的幸运硬币,你是猜正还是反?
本文分享了一个简单有趣的编程案例——猜硬币正反面游戏。通过模拟抛硬币(0为正面,1为反面),用户输入猜测值,程序判断结果并输出。
140 0
【Java实例-神秘硬币】用Java投掷你的幸运硬币,你是猜正还是反?
|
6月前
|
存储 算法 Java
【Java实例-智慧牌局】Java实现赌桌上的21点
游戏规则:游戏开始时,玩家和庄家各获得两张牌,玩家可以看到自己手中的两张牌以及庄家的一张明牌。玩家需要根据手中的牌面总和,选择“要牌”(Hit)以获取更多牌,或“停牌”(Stand)停止要牌。如果玩家的牌面总和超过21点,即为爆牌,玩家立即输掉游戏。若玩家选择停牌,庄家则开始行动,其策略是当牌面总和小于17点时必须继续要牌。若庄家牌面总和超过21点,则庄家爆牌,玩家获胜。若双方均未爆牌,最终比较牌面总和,更接近21点的一方获胜;若牌面总和相同,则游戏以平局结束。
94 0
|
8月前
|
前端开发 JavaScript Java
【Java进阶】JavaScript电灯开关实例:从理论到实践
这个例子展示了JavaScript的基本功能,包括操作HTML元素,监听事件,以及改变元素的样式。通过学习和理解这个例子,你可以了解到JavaScript在网页中的应用,以及如何使用JavaScript来创建交互式的网页。
177 13
|
6月前
|
Java 开发者
【Java实例-英雄对战】Java战斗之旅,既分胜负也决生死
游戏规则:在“英雄对战”中,玩家和敌人轮流选择行动,目标是在对方生命值归零前将其击败。游戏开始时,玩家和敌人都有100生命值。每回合,玩家可以选择“攻击”,“追击”,“闪避反击”这三种行动之一。
76 0

推荐镜像

更多
  • DNS